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AW‏ اساسیات لینکس 


فقد خطت المملكة العربية السعودية في ظل قیادتتا الرشيدة خطوات واسعة من اجل تحقيق الرقي والرخاء للوطن 
والمواطن. وستکون روية ۲۰۳۰ خير شاهد على مستوی التطور والحضارة التي ستشهدها المملكة والتي ستأخذها 
الى مصاف الدول المتقدمة من خلال تنویع مصادر الدخل والاهتمام شی الکفاءات الوطنية للمساهمة في بناء 
اقتصاد قوي ومستدیم. وتعتبر الموسسة العامة لغ ریب التقتي والمهتي من باکورة المشاریع الحفيقة للاستشمار في 
الأنسان السعودي في الاستراتیجیات السابقة واللاحقة وذلك بدورها الرائد بتدریب وتأهیل سواعد ابناء هذا البلد 


المعطاء من أجل إدارة الدفة الصناعية والحرفية بنا بحقق أعلى معاییر الكفاءة والسلامة المهنية. 


وفي ظل ذلك الزخم من الاهتمام والرعاية قامت المؤسسة العامة للتدریب التقني والمهني بابرام عقود مع کبری 
الشرکات العالمية بهدف الرقي بمستوی ابنائنا المتدربین وتمكينهم من الحصول على المناهج الحديثة و المتطورة 
من خلال المراکز والأكاديميات الرائدة. ونظرا لأن بعض تلك المناهج لا توجد لها اصدارات تخدم اللغة العربية 
وما لذلك من تبعات تحول بین المتدرب وبين الاستقاء الکامل لتلك المعارف والمناهل» فقد بادرت بترجمة لأحد 
تلك المناهج بتصرف وهو منهج اكاديمية سیسکو: اساسیات نظام التشغیل لینکس لیصبح الحقيبة التدريبية المكافئة 


لمادة نظم تشغیل ۲ . 


يحتوي منهج اساسیات لینکس NDG Linux Essentials‏ على ستة عشر فصلاء ثلائة فصول نظرية Ais,‏ 
وهي الثلاثة الفصول الأولی» واما باقي الثلائة عشر فصلاً وتحدیداً من الفصل الرابع إلى الفصل السادس عشر 
فتشتمل على جزء نظري وجزء عملي. في هذا العمل قمت بترجمة الثلائة الفصول النظرية الأولى وهي الفصل 


الأول والثاني والثالث ثم ترجمة المعامل من المعمل الرابع إلى المعمل السادس عشر. 


d als‏ ارجو من القاری الکریم ابداء اي آراء أو ملاحظات على المحتوی على بريدي الالكتروني 
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الهدف 


منهج أساسيات لینکس هو منهج الكتروني موجود في موقع أكاديمية سیسکو العالمية في الشبكة العنكبوتية» ویهدف 
إلى تعلیم المتدربین مفهوم البرمجیات المفتوحة المصدر وأساسيات نظام التشغیل لینکس» ثم الانتقال إلى القدرة 


على اتقان التعامل مع عملیات سطر الأوامر الأساسية. 
الأهداف التفصيلية 


ه التعرف على البرمجیات الحرة المفتوحة المصدر والتراخیص. 
e‏ التعرف على التطبیقات المفتوحة المصدر في مکان العمل و علاقتها بالتطبیقات ذات المصدر المغلق, 
e‏ التعرف على المفاهیم الأساسية لنظام التشغیل لینکس من أجهزة و عملیات وبرامج ومکونات. 

e‏ القدرة على العمل على سطر الأوامر والملفات. 

٭ القدرة على انشاء و استعادة النسخ الاحتياطية المضغوطة وحفظها. 

e‏ القدرة على استکشاف وتکوین اجهزة الحاسب الالي على الشبكة. 

٭ القدرة على تأمين النظام للمستخدمین و المجموعات و!عطاء أذونات ملفات الدلائل العامة والخاصة. 


۰ القدرة على إنشاء وتشغيل البرامج النصية البسيطة. 


الفنة المستهدفة 


بستهدف هذا العمل متدربي قسم الحاسب الالي بالکلیات التقنية في تخصصي دعم فني وشبکات» Cus‏ يدرس 
مر کک شاک نگ تفيل xa ١‏ شین Aes]‏ الشروية مین اتی هذا اخری يسفن ات 


الاساسية لعالم الاحتراف في استخدام نظام التشغيل لینکس. 


کک 


250 اساسيات لينكس‎ pM 


المهارات المطلوب اتقاتها 


ه اتقان استخدام برنامج القشرة. 

o‏ اتقان كيفية الحصول على المساعدة في الأوامر والبحث عن الملفات. 

o‏ اتقان كيفية التنقل وإدارة الملفات والدلائل. 

e‏ اتقان كيفية التعامل مع ملفات الأرشيف. 

٭ اتقان كيفية إعادة توجيه حزم النص واستخدام التعابير العادية وأوامر تصفية الملفات النصية. 
e‏ اتقان كيفية استخدام محرر النصوص لانشاء البرامج النصية في القشرة الأساسية. 

e‏ اتقان أوامر عرض المعلومات عن أجهزة الحاسب والعتاد. 

e‏ معرفة موقع النواة وبياناتها وايضا معلومات معالجة المكتبات وملفات السجل وحزم البرمجيات. 
ه معرفة كيفية حماية المستخدم للنظام. 

e‏ اتقان كيفية إنشاء حساب لمستخدم جدید» وإنشاء كلمة مرور وإجراء التعديلات لهذا الحساب. 
e‏ اتقان كيفية إعداد وعرض الملكيات وأذونات الملفات والدلائل. 


e‏ معرفة الأذونات الخاصة والأنواع المختلفة من ملفات الارتباط. 


الوقت المتوقع لأنهاء هذا المنهج: 


يحتوي هذا المنهج على ستة عشر فصل ومعملء الثلاثة الفصول النظرية يمكن تغطيتها في الاسبوعين الأولى 


في اکادیمیة سيسكو العالميةء بالإضافة إلى معالجة الملاحظات السابقة مثل: 


e‏ مراجعة شاملة كاملة للنص للتأكد من خلوه من الأخطاء. 

ه تحديث المحتوى تبعاً لمنهج اكاديمية سيسكو العالمية. 

o‏ إعادة شرح بعض المواضيع وتبسيط محتواها. 

هه مطابقة تنسيقات اكاديمية سيسكو. 

e‏ تغيير بعض المصطلحات المترجمة لتتواكب مع لمصطلحات المعربة سابقا. 
e‏ تطعيم النص بالمزيد من المصطلحات الإنجليزية التخصصية. 

o‏ الاستغناء عن الصور قدر الإمكان وتحسين جودة ما تبقى. 

e‏ عمل فواصل بين الفصول. 


o‏ إغادة صياغة الملحقات وتصحيحها: 


التطوير في الإصدارات القادمة 


ه متابعة ما یتم من تجديد للمنهج في موقع اكاديمية سيسكو وتحديث المحتوى تبعا لذلك. 
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ما الجدید فی الاصدار الثانی 

هذا هو الإصدار الثاني لترجمة منهج سيسكو أساسيات لینکس» وتم فيه تحديث مماتل للمنھج الرنيسي الموجود 

ه عمل فهرسة للأشكال الموجودة في المنهج. 


الويب The web based content‏ . ورغم ان المحتوی یتم عرضه عن طريق الانترنت. الا ان الجهاز 


الظاهري virtual machine‏ معزول عن الانترنت» حيث انه صمم ليكون بيئة ali‏ آمنة .safe sandbox‏ 
يعمل الجهاز الظاهري virtual machine‏ على نظام التشغيل أوبونتو Ubuntu‏ الاصدار ۱۲,۱۰. والذي 
يستخدم نسخة مخففة من نظام التشغيل» حيث تم إزالة بعض الأوامر التي لم يتم شرحها في هذه الدورة. 

النافذة الافتراضية Virtual Terminal‏ تتوفر أثناء قراءة محتوى أي فصل أو معمل. ويتم فيها ادخال وتنفيذ 
الأوامر دون الحاجة الى تثبيت نظام تشغيل جديد او نظام افتراضي على الحاسب الخاص بك. وبما ان هذه النافذة 
افتراضية فهي لا تقوم بتخزين أي بيانات أو تعديلات فيها عند اغلاقها. 

لعرض المحتوى التدريبي ووحدة تحكم لینکس Linux console viewer‏ يجب استخدام asd‏ برامج استعراض 


الويب. اما الحد الأدنى من تلك البرامج فهو كالتالي: 


e‏ برنامج Us s»‏ کروم Google Chrome‏ الإصدار ۲۰ او أعلى. 


برنامج سفاري Safari‏ الإصدار ١ر٦‏ أو أعلى. 


e‏ برنامج فاير فوكس موزیلا Mozilla Firefox‏ الاصدار ٥٢‏ أو أعلى. 


برنامج انترنت إكسبلورر Internet Explorer‏ الاصدار ٠١‏ أو أعلى. 


یحصل المتدرب بعد انتهاء البرنامج على شهادة من اكاديمية سیسکو العالمية تفید بتجاوزه لهذا المقرر وانه QA $a‏ 
للتفديم على اختبار LPI Linux Essentials Exam‏ ولحصول على شهادة اساسیات نظام التشغیل لینکس 


.LPI Linux Essentials Exam 
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لنكس Linux‏ هو نظام تشغيل مفتوح المصدر؛ بمعنى ان الکود أو التعليمات البرمجية الذي يحرك لینکس صنمم 
من قبل نفس المستخدمين للنظام» وبالتالي لا تمتلكه جهة معينة. وميزة هذا النظام انه يسمح لأي شخص استخدامه 
من غير تكاليف ترخيصء وأيضا يتيح لذلك الشخص إمكانية تعديل الكود وتغييره بما يتوافق مع الاحتياجات 


المتجددة. 


لنكس هي علامة تجارية مسجلة في الولايات المتحدة وبلدان أخرى للسويدي لينوس تور فالدس. 


Linux is Üpen Source. 


What does that mean? 


The code that powers 
Linux isn't owned by 


itis 


Instead 5: 
r by the 


community that uses it. 


Why is this good? 


It frees users from licensing costs & allows the 
code to be modified to meet changing needs. 
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۱,۲ تطور Si‏ وأنظ خی 1 3 رة 


لینکس يعني نواة النظام «kernel‏ وهي وحدة تحکم مركزية لکل ما یحدث على جهاز الحاسب الالي. عندما نقول 
ان جهاز الحاسب "يعمل بنظام لینکس" فذلك اشارة إلى النواة ومجموعة من الأدوات 86 التي تأتي معها 
(تسمى التوزيع (distribution‏ وإذا كانت لديك خبرة في نظام التشغيل لينكس فأنت على الأرجح تتحدث عن 


البرامج نفسها. 


مصطلح UNIX‏ يربك قلیلاء حيث ان يونيكس أصلا هو نظام تشغيل تم تطويره في مختبرات Bell Labs‏ 


AT&T‏ وذلك في عام ۱۹۷۰. ثم أجريت عليه تعديلات (تم التعدیل من قبل المجتمع ثم أصبح ذلك التعدیل أساس 


ذلكء يونيكس الآن علامة تجارية trademark‏ ومحددة tspecification‏ ومملوكة من قبل اتحاد صناعي 
يسمى المجموعة المفتوحة Open Group‏ البرنامج الوحيد الذي تم اعتماده من قبل المجموعة المفتوحة هو 


لينكس في الحقيقة ليس يونيكس! ولكنه "مثل يونيكس" .UNIX-like‏ 
1 دور الثؤاة 


نواة نظام التشغيل kernel‏ تدير النظام؛ فمثلا تخصص للبرامج جزء من الذاکرة» وتقوم بتشغيل وانهاء البرامج» 
رکال مع ری الم .على 3 Lade‏ يتاع ليق إلى ایا على الازمن الب فج آن يلات 
ذلك من نظام التشغيل. ايضا إذا قام تطبيقان بطلب نفس الموارد فان النواة هي التي تقرر من التطبيق الذي 
سيحصل عليهاء وفي بعض الحالات تنهي تطبيق من أجل إنقاذ النظام. 

أيضا من مهام النواة التبديل بين التطبیقاتء يعني أن الحاسب يقوم بالعديد من التطبيقات المفتوحة في آن واحد» 
فتعالج النواة التنقل بين تلك التطبيقات. اما تعدد المهام الاستباقي pre-emptive multitasking‏ يعني أن 
النواة هي التي تحدد موعد تبديل التركيز بين المهام وذلك لأن الحاسب لديه عدد محدود من الموارد كالذاكرة 


مثلاً؛ فلا يريد ان يستحوذ برنامج واحد على كل الموارد. 


M 
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قد يظن کل تطبيق ان لديه جزء كبيرة من الذاكرة في النظام» لکن في الحقيقة النواة هي التي تحافظ على هذا 


الوهم. 


عند بدء تشغیل الحاسب یتم تحمیل جزء صغير من التعلیمات البرمجية يسمى محمل الاقلاع .boot loader‏ 
وظيفته تحمیل نواة النظام وبدء التشغيل. حيث يقوم محمل الاقلاع بتحميل نواة لینکس, ثم نقل السيطرة إلى نظام 
التشغيل. ثم يستمر نظام التشغيل لینکس بتشغیل البرامج اللازمة لجعل الحاسوب مفیدء مثل الاتصال بالشبكة أو 
تشغیل خادم ويب. 


۱,۲,۲ التطبيقات 


مثل وحدة تحكم الحركة الجوية النواة ليست مفيدة من دون شيء للسيطرة عليه. فإذا كانت النواة هي البرج 
والتطبيقات هي الطائرات؛ فالتطبیقات ترسل طلباتها إلى النواة وذلك لاستقبال الموارد مثل الذاكرة ووحدة المعالجة 
المركزية. 

العملية process‏ هي مهمة تقوم النواة بتحميلها ثم تتبع نتائجها. وأحيانا يحتاج التطبيق إلى أكثر من Adae‏ 
فالنواة هي التي تهتم بذلك. 

۳ دور المصدر المفتوح 

بدأ لينكس في عام ۱۹۹۱ كمشروع هواية من قبل لينوس تور فالدس. وقام بعرض كود المصدر (التعليمات 
البرمجية) بحرية وانضم آخرون اليه لتشكيل هذا النظام. 


مشاريع البرمجيات تأخذ شكل الكود المصدر «source code‏ والذي هو عبارة عن مجموعة من تعليمات 
الحاسب المقروءة للإنسان والتي يمكن كتابتها بأي من لغات البرمجة المختلفة. الجدير بالذكر أن كود المصدر 


نظام التشغيل لينكس مكتوب بلغة (C.‏ مما يجعله شبيهاً بنظام يونيكس UNIX‏ ايضا. 


المترجم compiler‏ يقوم بتحويل كود المصدر (الغير مفهوم مباشرة بواسطة الحاسب) إلى أوامر وتعليمات. 


حيث يجمع المحول كافة ملفات المصدر ويحولها إلى صيغة يمكن تشغيلها على جهاز الحاسب. مثل نواة لينكس. 


٤ 
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المصادر المفتوحة open source‏ هي أن لديك الحق في الحصول على البرنامج وتعدیله كما ترید. فقام 
مستخدمو لینکس بأخذ كود المصدر وإجراء تغیرات عليه ثم مشاركته مرة أخرى. وقد أدى اعتماد لينكس على 


هذه الفلسفة إلى نجاح كبير. 


تاريخيا؛ اغلب البرامج تكون مغلقة المصدر closed-source license‏ بمعنى أنك تستطيع تشغيل البرنامج 
لكنك لا تستطيع ان تعدل على الكود الاصلي المكون للبرنامج. وذلك عكس البرامج المفتوحة المصدر Open‏ 


source‏ والتي dll as‏ من الدخول على الكود الاصلي والتعديل فيه. 


في البداية كان هذا النظام اسمه جنو GNU‏ ولیس يونيكس. بينما كان مطوري جنو يبنون نظام التشغيل الخاص 
بهم وجدو انهم أكثر فعالية في بناء الأدوات التي تتماشى مع نظام التشغيل يونيكس ولكنهم لم يبنوا النواة بعد فتم 
استخدام نواة لينكس والتي وفرة نظام تشغيل كامل. من ذلك يتضح لنا أن معظم الأدوات (التي هي جزء من نظام 


لينكس) تأتي من مشروع جنو. 


تغيرات تمت بو اسطة | لمجتمع. 


٤‏ توزیعات لینکس 


عند أخذ نواة لینکس وأدوات جنوء ثم إضافة تطبیقات مرئية للمستخدمين مثل عميل البريد الإلكتروني؛ عند اذن 
يصبح لدينا نظام لينكس كامل. وتقريبا منذ بدأ استعمال لينكس؛ بدأ المستخدمون بتجميع كل تلك التطبيقات والبرامج 
في حزمة متكاملة تسمى التوزيع .distribution‏ التوزيع distribution‏ يعتني بتخزين وتركيب النواة» وتنزيل 
بقية البرنامج. وتشمل نسخة التوزيعات الكاملة على أدوات لإدارة النظام؛ وأيضا على مدير 
مجموعة package manager‏ للمساعدة في إضافة وإزالة البرامج بعد اكتمال التثبيت. 

تختلف التوزيعات باختلاف استخدامها؛ فبعضها يهتم بالخوادم servers‏ والبعض الاخر يهتم بالجهاز المكتبي 
s desktops‏ هناك توزيعات مصممة لأغراض تجارية كأدوات التصميم الالكتروني أو الحسابات الاحصائية. 
ويمكن القول ان اهم توزيعيتين في فترة البدايات هما ريد هات Red Hat‏ ودیبان Debian‏ وتوجد اختلافات 


3o 
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بینهما في کل شيء من مراقع الملفات file locations‏ إلى الفلسفات السياسية ‘political philosophies‏ 


ولكن الفرق الأكثر وضوحا بينهما هو في مدير المجموعة .package manager‏ 


هات بزيادة التركيز على تطبيقات الخادم server‏ مثل شبكة الانترنت» وخدمة الملفات» وأصدر ريد هات 
إنتربرايز لينكس Enterprise Linux‏ وهي خدمة مدفوعة على دورة إصدار طويلة long release cycle‏ 


اما دور دورة الاصدار release cycle‏ فهو لتوضيح متى يحتاج البرنامج إلى ترقية. 


نظام Debian‏ هو M‏ مجتمعي وهو يشجع على استخدام البرمجیات المفتوحة المصدر. جاء ديبان مع نظام 
إدارة المجموعة الخاصة به استنادا إلى تنسيق ملف ديب edeb file format‏ وهو عكس ريد هات Cus‏ يدعم 


المعالجات التي لا تكون انتل Intel‏ أو أ م د .AMD‏ 


لينكس العلمي Scientific Linux‏ هو مثال اخر على التوزيعات المخصصة specific distribution‏ 


والمبنية على ريد هات. والذي هو عبارة عن توزيعات distribution.‏ تتعامل مع الحسابات العلمية. 


أوبونتو Ubuntu‏ هو أكثر نظام تشغيل شعبية» وتوزيعاته مأخوذة من ديبان. شركة كانون يكال Canonical‏ 


انشأته بغرض اخذ ارباح من تقديم الدعم. 


لينوكس منت Linux Mint‏ بدأ بمثابة فرع لأوبونتو لينكس «Ubuntu Linux‏ حيث لا يزال يعتمد على 
مستودعات أوبونتو Ubuntu repositories‏ ولديه إصدارات مختلفة جميعها مجانية» ولكنها تحتوي على 
بعض برامج الترميز والملكية» والتي لا يمكن توزيعها دون قيود الترخيص في بعض البلدان. لينوكس منت 


سرعان ما حل كأفضل مكتبي في العالم لأوبونتو. 


لقد ناقشنا التوزيعات المذكورة على وجه التحديد في أهداف أساسيات لينكس. يجب أن تكون على علم بأن 
هناك مئات - إن لم يكن الآف - من التوزيعات المتوفرة. من المهم أن نفهم أنه في حين أن هناك العديد من 


توزيعات المختلفة من لینکس ولكن العديد من البرامج والأوامر كما هي أو مشابه جدا لما سبق. 


معین» عندما تكتب امر فان العملية ككل process‏ تنفذ بواسطة نظام التشغيل الذي يقرا المدخلات ويعدل 
البيانات ثم یخرج النتائج. وبالتالي فان الأمر يقوم بتنفيذ عملية process‏ لأنجاز مهمة معینة job‏ ايضا يمكن 
تعريف الأمر من زاوية اخری وهي مكان الاصدار لذلك الأمرء فهناك مصادر مختلفة للأوامر داخل القشرة 


shell‏ في سطر الأوامر CLI‏ الخاص بك مثل: 


e‏ الأوامر المضمنة في نفس القشرة shell‏ وخیر مثال هو الأمر cd‏ لأنه جزء من قشرة الباش 
bash shell‏ عندما يكتب المستخدم الأمر «cd.‏ فان القشرة shell‏ تنفذ الأمر لأنها تعرف تفسير هذا 
الأمر؛ ولا تتطلب برامج إضافية لذلك. 

e‏ الأوامر المخزنة في ملفات وتكون القشرة مسؤولة عن البحث عنها: مثل الأمر [s‏ والذي عند کتابته 
تقوم القشرة بإرجاع قائمة الملفات الموجودة في ذلك المسار .PATH variable‏ 

ه الأسماء المستعارة Aliases‏ وهي تستخدم لاستحداث أوامر جديدة وذلك ببنائها من المهام والأوامر 
الموجودة .Functions‏ 

e‏ وظائف Functions‏ ويمكن أيضا أن تبنى الوظائف باستخدام الأوامر الموجودة ايضا مثل الأسماء 
المستعارة Aliases‏ وذلك لإنشاء أوامر جديدة بهدف تجاوز الأوامر المضمنة في القشرة shell‏ أو 


الأوامر المخزنة في الملفات. 


يتم تحميل الوظائف والأسماء المستعارة من ملفات التهيئة عندما تبدأ القشرة. 


الاسم المستعار هو في الأساس اختصار لأمر أو سلسلة من الأوامر الأخرى. على سبيل المتال» فان الأمر Cal‏ 
4 يعرض التقويم لعام .٤١٠٢‏ بدلا من تنفيذ الأمر الكامل في كل مرة» يمكنك إنشاء اسم مستعار يسمى 
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١‏ ماهو الأمر 

الأمر command‏ هو برنامج software program‏ عند sé‏ على سطر الأوامر يقوم الحاسب بعمل 

عما هو موضح في الصورة التالية: 
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sysadmin@localhost:~$ alias mycal-"cal 2014" 


sysadminllocalhost:~$ mycal 
2014 


January February 
Su Mo Mu We Ma وا‎ 8 Mo Tu We Th 
LL ZS CA 
7 لو‎ + + n9 1 
14 15 1$ ۶٤ 
21 22 23 24 295 


Z9 29 30 1 


April 


Tu We Th 


15 1G 17 16 
22 23 24 23 
29 30 30 


July September 


Tu We Th Mo Tu We Th 


1 2 3 ال‎ 2 3 A 


التقويم الميلادي لعام 4 ۲۰۱ 
۱,۲,۵ منصات الأجهزة 
بدا لینکس بدعم معالج TAT‏ ومع التقدم المستمر تطور النظام لیدعم منصات اخری من شريحة انتل Intel‏ 
chip‏ إلى الحاسبات الكبيرة „supercomputers‏ 


ثم استخدم لینکس في أنظمة الهواتف الخلوية cellular phones‏ واللوحية tablets‏ اخیرا بيعت إلى جوجل 
6 الذي جاء مع منص آند رويد Android.‏ الذي هو عبارة عن لینکس والبرامج اللازمة لتشغیل الهاتف 


أو الحاسب اللوحي. حیث تستطيع الشرکات المنتجة للهواتف المحمولة استخدامه کنظام لهواتفهاء وبالتالي یکون 


الانظمة market leaders‏ في عالم الهواتف. 


يمكن ايضا العثور علي لينكس في العديد من الأجهزة الاستهلاكية consumer devices‏ مثل موجهات الشبكة 
اللاسلكية Wireless routers‏ والتي في كثير من الأحيان تعمل بنظام لینکس لأنه غني بمميزات 
الشبكة network features‏ . ايضا هناك تيفو 111/0 مسجل فيديو الرقمي خاص بالمستهلك consumer‏ 


digital video ۲‏ والذي يستخدم أيضا نظام لينكس. 
کار ا اکن 


لینکس هو نظام تشغيل مماثل لنظام یونیکس UNIX-like‏ مما يعني أنه ليس له شهادة رسمیةء وبالتالي لا یمکن 
استخدام العلامة التجارية لنظام يونيكس UNIX.‏ هناك العديد من البدائل الأخرى؛ بعضها مماثل لنظام يونيكس 
والبعض معتمد باسم كنظام يونيكس UNIX‏ وهناك أيضا أنظمة ليست مماثلة لنظام یونکس non-Unix‏ مثل 


مايكروسوفت ویندوز. 


السؤال الأهم لاختیار نظام التشغيل هو "ما الذي تفعله هذه الآلة؟". 
۱ نقاط القرار 


إن أول شيء عليك أن تقرره هو ما الدور الذي سيؤديه هذا الجهاز. هل ستعمل على وحدة التحکم console‏ 
وتقوم بتشغيل التطبيقات الإنتاجية أو إنك ستتصفح الانترنت؟ إذا كانت هذه هي الحالة فانت تحتاج إلى حاسب 
سطح مکتب. أما إذا كان سيستخدم كخادم ويب Web server‏ وسيكون في رف الخوادم؛ فانت اذن تحتاج إلى 


خادم. 
عادة الخوادم oS Servers‏ في رف rack‏ وتتقاسم شاشة ولوحة مفاتيح مع العديد من أجهزة الحاسب الأخری 
ايضا وحدة التحکم console‏ تستخدم فقط لإعداد واستكشاف الاخطاء وبالتالي سيعمل الخادم في الوضع الغير 


رسومي non-graphical mode‏ بعكس الحاسب العادي الذي يعمل بواجهة رسومية .GUI‏ 


2 m 
Myr 
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$38 تركيزهم على انتاج التطبيقات لا على نظام التشغيل مما سهل عملية التصنيع. لهذا فان أند روید يعتبر أحد‎ 
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ثانيا حدد وظائف الجهاز. هل هناك برامج معينة سيقوم الجهاز لتشغيلهاء أو وظائف محددة عليه أن یفعلها؟ يجب 
عليك أيضا تحديد مدى الحياة lifetime‏ والمخاطر المحتملة risk tolerance‏ للخادم» فعادة أنظمة التشغيل 
والبرامج يصدر لها تحديث بشکل دوري وهو ما يسمى بدورة الاطلاق release cycle‏ لکن منتجي البرامج 
سيدعمون الإصدارات القديمة من البرامج لفترة من الوقت ثم لا يكون لها أي تحدیث» وهو ما يسمى دورة صيانة 
maintenance cycle‏ أو دورة الحياة life cycle‏ على سبيل المثال؛ التحديثات الرئيسية للينكس تصدر 
كل ٦‏ أشهر تقريبا. الجدير بالذكر ان الإصدارات تعتبر منتهية الحياة End of Life (EOL)‏ بعد تحديثين 
رئيسيين بالإضافة إلى شهر واحد» بحيث يكون المجموع ما بين ۷ و۱۳ شهر بعد التثبيت قبل أن الحاجة إلى 
عمل ترقية. على العكس من ذلك مع البديل التجاري مثل ريد هات إنتربرايز لينوكس Red Hat Enterprise‏ 


Linux‏ والذي يمكن أن تستخدمه لمدة ۱۳ سنة قبل أن تحتاج إلى ترقيته. 


الصيانة ودورة الاصدار مهمة في الخادم التجاري enterprise server‏ لأنه في بيئة تستهلك بالوقت» لکن 
الوقت» لکن الترقية فيه غير هامة (jy‏ الخادم نفسه يستبدل في حال وجود تحديثات كبيرة في أنظمة التشغيل 
وتطبيقاتهاء لذلك تكون دورة الاصدار القصيرة cycle‏ 6 بطيئةء وذلك لأن التطبيقات غالبا ما تستهدف 


الإصدار الحالي من نظام التشغيل بغرض تجنب عناء ترقية الخوادم وأنظمة التشغيل باستمرار. 


إذا كنت مطور للبرمجيات أو مستخدم تقليدي للينكس المكتبي فانت تحتاج لأحدث البرامج والتي تختلف في 
المظهر والوظائفء في الغالب يخزن المستخدم المكتبي عمله في أحد الخوادم وبالتالي يستطيع الترقية سوآءا 


لنظام التشغيل أو البرامج دون القلق على عمله السابق. 


ان أحد الأشياء العظيمة في المصدر المفتوح هو أن المطور يمكنه إطلاق البرنامج الجديد والحصول بسرعة على 
التغذية الراجعة feedback‏ من المستخدمين. بيتا beta‏ هو إصدار فيه العديد من الميزات الجديدة ولكن لم 
يتم اختبارها بدقة» بعد أن يتم اختبار النسخة يتم اطلاق اصدار جديد وهو المستقر stable‏ لذلك يمكن وصف 


إصدارات البرامج الفردية بانها اما بيتا beta‏ أو مستقرة „stable‏ 


مفهوم التو افق backward compatibility.‏ وهو قدرة نظام التشغيل الجدید على التعامل مع البرامج التي 


A " ۲‏ ۳ التڈ خی السابقة. 


و اساسیات لینکس 2230 


التكلفة cost‏ هي دائما أحد العوامل المأخوذة في الحسبان عند الاختیار» على سبيل المثال نظام تشغيل لینکس في 
حد ذاته مجاني ولكن المستخدم قد يحتاج إلى دفع تكاليف للدعم اعتمادا على المميزات التي يختارها. وفي الجهة 
المقابلة ايضا مايكروسوفت Microsoft‏ لديها تكاليف ترخيص الخادم وربما تكاليف الدعم الإضافية على مدى 


عمر الخادم. 
۲ مايكروسوفت ويندوز 


مايكروسوفت قسمت انظمة التشغيل وذلك وفقا للغرض من الجهاز إلى: مكتبي desktop‏ أو الخادم *server‏ 


اصدارات ويندوز المكتبي مثل ويندوز ۸ تخرج كل Y‏ إلى ٥‏ سنوات» وتميل إلى الدعم لسنوات عديدة. التوافق 


هو أيضا أولوية لمايكروسوفت» بحيث يمكن للمستخدمين تشغيل البرامج القديمة. 

في عالم الخادم server‏ هناك نظام التشغيل Windows Server‏ (نسخة ۲۰۱۲ للدلالة على تاريخ اطلاقه) 
وله واجهة المستخدم الرسومیة وهو منافس للينكس إلى حد كبير. 

Apple Jd‏ تجعل من OS-X‏ نظام التشغيل» الذي خرج بشهادة UNIX‏ ويستند OS-X‏ جزئيا إلى مشروع 
.FreeBSD‏ 


يعتبر OS-X‏ نظام تشغيل مكتبي ولكن هناك حزم اختيارية تساعد في إدارة خدمات الشبكة» وذلك الحزم 
5 تسمح للعديد من الاجهزة المكتبية OS-X desktops‏ بالتعاون مع بعضها البعض» مثل مشاركة 


الملفات أو تسجيل الدخول للشبكة. 


استخدام OS-X‏ على مكتبي عادة ما يكون قرار شخصي نتيجة سهولة الاستخدام. وبتزايد شعبية OS-X‏ توفر 


دعم مناسب من المنتجين. ايضا OS-X‏ ذا شعبية كبيرة في الصناعات الإبداعية مثل إنتاج الفيديو. 
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هناك العديد من المشاريع المفتوحة المصدر "توزیع برامج بيركلي "Berkely Software Distribution‏ 
مثل FreeBSD; OpenBSD‏ و «NetBSD‏ وهي تعتبر بدائل لنظام لینکس في كثير من النواحي لأنها 
تستخدم كمية كبيرة من البرامج المشتركة. تدمج 85105 عادة في الخادم» وفي المقابل هناك lel gil‏ تم تطویرها 


للقيام بأدوار سطح المکتب Dia‏ جنوم GNOME‏ وكيدي KDE‏ 
٥‏ انواع تجارية آخری من Unixes‏ 
بعض من انواع ينكس Unixes‏ التجارية الأکثر شعبية هي: 


Oracle Solaris e 
IBMAIX ۰ 


HP-UX e 


وکل منها يعمل بمنظور مخترعیها أو مطوریها. وعادة يكون العتاد فيها hardware‏ كبير وقوي» وتقوم بتقديم 
مميزات مثل التبدیل الساخن للمعالج والذاكرة chot-swap CPU and memory‏ أو التکامل مع النظم 


legacy mainframe systems المركزية القديمة‎ 


معظم المستخدمين یمیلون إلى اختبار منتجات شركاتهم وفق ما یفضلون - الا إذا کان هناك برنامج ما یتطلب 
أجهزة معينة أو ان تطبيق application‏ بتطلب (ضافة ملحقات إلى الأجهزة الموجودة. على سبيل المثال» 
يعمل |BM-AIX‏ على مجموعة واسعة من عتاد [BM‏ ويمكن مشاركة العتاد مع النظم المركزية „mainframe‏ 
وهكذاء تجد AIX‏ في الشركات التي لديها بالفعل بصمة كبيرة ل 181/1 أو التي تستخدم برنامج IBM‏ مثل 


.WebSphere 
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٦‏ لينكس 


جانب واحد في لينكس یختلف عن غيره من البدائل وهو بعد اختیار المسؤول administrator‏ لنظام لینکس 
لا يزال عليه اختيار التوزیعات distribution‏ كما ذكر في الموضوع الأول عن التوزیعات distribution‏ 
والنواة Kernel‏ والمرافق utilities‏ وأدوات الإدارة management tools‏ فيقوم المسؤول بتثبيت الحزم 


initial installation بعد التثبيت الأولي‎ update وتحمیل التحديثات‎ package 


بعض أنظمة التشغيل متوفرة من خلال مورد واحد فقط Windows.» OS-X Jis‏ ويكون دعمها من خلال 
نفس المورد. لکن في لينكس Linux‏ هناك خيارات عديدة؛ وتبدأ من العروض التجارية المقدمة للخادم Server‏ 
أو لجهاز مكتبي «Desktop‏ إلى ان نصل إلى التوزيعات المعدلة والتي تحول جهاز حاسب قديم إلى جدار حمایة 


.firewall network للشبكة‎ 


في كثير من الأحيان يختار المنتجین مجموعة فرعية من التوزیعات للدعم. وبما ان للتوزیعات إصدارات مختلفة 


من المکتبات الرئيسية فأنه من الصعب علی الشرکة تقدیم الدعم لجمیع تلك الاصدارات. 


الحكومات والشركات الكبيرة أيضا تحد من خیاراتها للتوزيعات لتختار ما يقدم له الدعم التجاري. وهذا أمر شائع 


في الشركات الكبيرة حيث الدفع للحصول على الدعم أفضل من المخاطرة بانقطاع واسع النطاق. 


التوزيعات أيضا لديها دورات اصدار Cycles‏ 6 وتكون أحيانا کل ستة أشهر. فاذا كانت الترقية غير 
مطلوبة فان كل إصدار يمكن ان يكون معتمد لمدة معقولة من الزمن. لذلك بعض اصدارات لينكس لديها دعم 


طويل المدى (LTS)‏ من ٥‏ سنوات أو أكثر في حين سيكون دعم الآخرين فقط لمدة عامين أو أقل. 


بعض التوزيعات تميز الإصدار حسب المرحلة من الاستقرار والاختبار أو الغير مستقر. والفرق بينهم أن الاصدار 
الغير مستقرة يقايض الثقة بالمميزات. فعندما يتم دمج الميزات في نظام لفترة طويلة وتظهر الكثير من المشاكل 
والاعطال؛ ينتقل البرنامج من خلال ذلك الاختبار إلى مرحلة الإصدار المستقر. توزيعة دبيان Debian‏ 


7 تحدر المستخدمين عن استخدام اصدار "sig"‏ بالتحذير التالي: 


sid "‏ " يخضع لتغییرات واسعة النطاق وتحديث للمكتبات. هذا يمكن أن يؤدي إلى "عدم استقرار" النظام؛ والذي 
يحتوي على حزم لا يمكن تثبيتها بسبب النقص في المكتبات» لذلك فالنتائج قد لا تحقق المطلوب. لذلك استخدمه 


على مسؤوليتك الخاصة! 


في الجهة الأخرىء يوجد توزيعات أخرى تعتمد على توزيعات بيتا „Beta‏ على سبيل المثال توزيع فیدورا 
Fedora distribution‏ أطلقت نسخة بيتا Beta‏ أو نسخة ما قبل الاصدار pre-releases‏ لبرنامجها قبل 
الاصدار الكامل للحد من الخلل. غالبا ما يعتبر المستخدمون فيدورا على أنها إصدار Beta Us‏ لنظام ريدهات 
RedHat‏ وبعد إضافة أو تعديل المميزات في فيدورا quad‏ جاهزة لتوزيع ريدهات RedHat‏ 


distribution 
Android نظام اندروید‎ ۷ 


يعتبر نظام اندروید Android‏ - برعاية جوجل - هو توزيعة لینکس الأكثر شعبية في العالم. وهو يختلف جوهریا 
عن نظرانه. لينكس هو النواة والعديد من الأوامر التي سيتم تغطيتها في هذه الدورة هي في الواقع جزء من حزمة 
جنو GNU)‏ ولیس يونكس). وهذا هو السبب في أن بعض الناس يصرون على استخدام مصطلح جنو / لینکس 


بدلا من لينكس فقط. 


يستخدم اندرويد Dalvik virtual machine‏ (الجهاز الظاهري دالفيك) مع لینکس» ويوفر منصة قوية للأجهزة 
المحمولة mobile devices‏ مثل الهواتف phones‏ والاجهزة اللوحية tablets‏ ومع ذلكء يفتقر اندرويد 
إلى الحزم التقليدية التي غالبا ما تأتي مع توزيعات لينكس ((Xorg 5 GNU sia Uis)‏ اندرويد لا یتفق عموما 


مع توزيعات لينكس لسطح المكتب. 


هذا التناقض يعني أن مستخدمي ريدهات RedHat‏ أو أوبونتو Ubuntu‏ لا يمكنهم تحميل البرنامج من متجر 
Play‏ 600016. وبالمثل؛ فان محطة المحاكي terminal emulator‏ في اندرويد تفتقر إلى العديد من 
الأوامر عن نظرائه في لينكس. ومع ذلك فمن الممكن استخدام BUSYBOX‏ مع اندرويد لتمكين معظم تلك 


الأوامر للعمل. 
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في هذا الفصل سوف تصبح العدید من التطبیقات المفتوحة المصدر وادواته مألوفة لديك. أيضا سوف نناقش 


برمجیات المصدر المفتوح والتراخیص. 
هل تعلم ان جمیع المواقع التالية تعمل بنظام لینکس: 


amazon e 
NETFLIX ۰ 

Tweeter e 
facebook هه‎ 


Google ۰ 


Did you know? 


All these 
companies 
run on Linux! 
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۲,۲ اهم : تطبیقات المصدر المفتوح 


نواة لینکس Linux kernel‏ تستطیع تشغیل مجموعة واسعة من البرامج عبر العدید من منصات العتاد 
hardware platforms‏ الحاسب یمکن أن يعمل کخادم server‏ مما يعني أنه یعالج البیانات نيابة عن 
الاخرین» أو يمكن أن يعمل کجهاز مكتبي desktop‏ للاستخدام المباشر مع المستخدم. الحاسب یستطیع تشغيل 
برامج أو ان یکون Je»‏ مطور development machine‏ لانشاء برامج. آیضا یمکنه لعب آدوار متعددة 
حيث ان لینکس Linux.‏ لا يميز دور الجهاز بل ولکن الأهم هي الاعداد والتي تحدد التطبیقات applications‏ 


المراد تشغیلها. 


الميزة هنا هو أنه يمكنك محاكاة simulate‏ تقریبا جمیع جوانب «production environment gY! äis‏ 
من تطویر development.‏ واختبار testing‏ وتحقق verification‏ وذلك بهدف تقلیص الأجهزة وبالتالي 
توفیر الوقت و التکالیف. لشخص يتعلم نظام لینکس LINUX‏ یمکنك تشغیل تطبیقات الخادم على جهاز مكتبي أو 
على الخادم الافتراضي virtual server‏ الذي يعمل على مزود خدمة الانترنت Internet Service‏ 
„Provider — (ISP)‏ وبطبيعة الحال لن تکون قادراً على التعامل مع مزود کبیر الحجم والذي لدیه أجهزة ذات 
تكلفة مرتفعة. ولکن يمكنك محاكاة أي تکوین configuration.‏ دون الحاجة إلى أجهزة قوية أو ترخیص الخادم 


.server licensing 


مه برنامج الخادم Server software‏ — وهي البرامج التي Y‏ تفاعل مباشرة مع الشاشة ولوحة المفاتیح 
للجھاز الذي تعمل علیه. والغرض منها هو خدمة المعلومات في أجهزة الحاسب الأخرى وهم العملاء 
6 أحيانا برنامج الخادم لا يتحدث إلى أجهزة الحاسب الأخرى ولكن فقط یتعامل مع البیانات. 

۷ه برامج مكتبية Desktop software‏ - وهي التي يمكنك التفاعل معها مباشرة Qua‏ متصفح الویب 
web browser‏ ومحرر النصوص text editor‏ ومشغل الموسیقی music player‏ في كثير 
من الحالات يتحدث البرنامج - مثل متصفح الانترنت - إلى الخادم server‏ على الطرف الاخر ومن 


ثم یقوم بتفسیر البیانات لك. في هذه الحالة فان البرنامج المكتبي سیصبح هو العميل. 


۷ 


G‏ اساسیات لینکس 


٭ آدوات Tools‏ وهي فنة واسعة من البرامج الغرض منها تسهيل إدارة النظام الخاص بك مثل الأداة 
الي تساعدك على تنسيق العرض. أو التي توفر لك قشرة لینکس «Linux shell‏ أو حتى الأدوات 


الأكثر تطورا والتي تحول كود المصدر source code‏ إلى مادة يمكن تنفيذها على الحاسب. 


اما بالنسبة إلى تطبيقات الجوال mobile applications‏ فهي مشابهة لتطبيقات الجهاز المكتبي ولكن يتم 
تشغيلها على الهاتف الجوال mobile‏ أو الحاسب اللوحي tablet‏ بدلا من جهاز الحاسب المكتبي desktop‏ 


.computer 


عادة تستطيع تنفیذ أي عمل تريده في لينكس بواسطة عدد من التطبيقات applications‏ فهناك العديد من 
متصفحات الويب web browsers‏ والعديد من خوادم الویب web servers‏ والعديد من برامج تحریر 
text editors oa saill‏ وهذا لا يختلف عن المصدر المغلق closed source‏ ولكن الميزة في المصادر 
المفتوحة open source‏ هي أنه لذا کان شخص ما لا تعجبه الطريقة التي يعمل بها خادم الویب Web‏ 


5 فانه يستطيع بناؤه بنفسه. وكلما تقدمت مع لينكس فستتعلم ايضاً كيفية تقییم البرامج المستخدمة. 
0١‏ تطبیقات الخادم 


لينكس تتفوق في تشغيل تطبيقات الخادم server applications‏ بسبب موثوقيتها reliability‏ وكفاءتها 
efficiency‏ وعند النظر في برنامج الخادم sserver software‏ فان السؤال الأكثر أهمية هو "ماهي الخدمة 
التي سأقوم بإدارتها؟" فمثلا إذا كنت تريد خدمة صفحات الويب tweb pages‏ فسوف تحتاج إلى برنامج خادم 


Imail server ولیس لخادم البريد‎ web server software الويب‎ 


العمل كخادم ويب web servers‏ هو أحد الاستخدامات المبكرة لنظام لینکس Linux‏ والذي یستضیف فيه 
صفحات pages c!‏ ۸۷۵۲ء ليتم بعد ذلك استعراضها بواسطة متصفح الانترنت من خلال بروتوكول نقل 
النص التشعبي (HTTP)‏ أو نسخته المشفرة iaia HTTPS‏ الویب web page‏ نفسها يمكن أن تكون احدى 
نوعين الأول هو ان تكون ثابتة static‏ مما يعني أنه عندما يطلب متصفح الويب web browser‏ الصفحة 
من خادم الويب web server‏ فان الخادم يرسل الملف كما يظهر على القرص disk‏ أما الثاني فهي المحتوى 


الديناميكي وهذا يعني أن يتم إرسال الطلب من قبل خادم الویب web server‏ إلى التطبيق application‏ 


Y^ 
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والذي سيقوم بتوليد المحتوی. برنامج وورد برس WordPress‏ هو أحد الأمثلة المعروفة. حيث يمكن 
للمستخدمين تطوير المحتوى من خلال متصفح الانترنت الخاص بهم في تطبيق وورد برس WordPress‏ 
والبرنامج يحوله إلى موقع تفاعلي functional website‏ على شبكة الانترنت بشكل كامل. في كل مرة تتسوق 


عبر الانترنت فانت تبحث في موقع ديناميكي. 


اباتشي Apache‏ هو خادم الويب web server‏ المهيمن حتى اليوم. كان أباتشي في الأصل مشروع مستقل 
ولكن المجموعة شكلت من قبل Apache Software Foundation‏ وهم الآن لديهم أكثر من مئة مشروع 


نجين اکس nginx‏ هو خادم ويب web server‏ آخر؛ slas‏ من دولة روسيا. وهو يركز على الأداء 
performance‏ من خلال الاستفادة من المزید من انوية يونيكس الحديثة modern UNIX kernels‏ آما 
على مستوى المهام» فأنه يقوم بعمل مهام فرعية subset‏ مقارنة بالمهام التي يمكن لأباتشي فعلها. الجدير 


بالذكر ان أكثر من ٦٦‏ من المواقع تعمل اما بخادم الويب نجن إكس nginx‏ أو أباتشي Apache‏ 


ولننتقل الآن من خوادم الويب إلى البريد الالكتروني» غالبا ما تستخدم خوادم لينكس LinUX Servers‏ في خدمة 


البريد الالكتروني. عند مناقشة هذه خدمة فإنه من المفيد دائما أن ننظر إلى ثلاثة أدوار مختلفة؛ لأنها حيوية 


للحصول على البريد الإلكتروني بين المستخدمين: 


-١‏ وکیل نقل البريد Mail Transfer Agent - (MTA)‏ - ليقوم بمعرفة أي خادم server‏ يحتاج 
لاستقبال البريد الإلكتروني exiis, «e-mail‏ بروتوكول نقل البريد :2 Simple Mail‏ 
Transfer Protocol - (SMTP)‏ لنقل البريد الإلكتروني إلى ذلك الخادم server‏ ليس من 
الغريب للبريد الإلكتروني e-mail.‏ ان يستغرق عدة قفزات hops‏ (بين الموجهات (Routers‏ 
للوصول إلى وجهته النهائية» وذلك لأن المنشأة قد يكون لها عدة وكلاء نقل بريد .MTAS‏ 

Local وايضا يسمى وکیل تسليم محلي‎ Mail Delivery Agent - (MDA) وکیل تسليم البريد‎ -Y 
في علبة البريد الخاصة بالمستخدم‎ e-mail وهو يقوم بتخزين البريد الإلكتروني‎ Delivery Agent 


user's mailbox‏ وعادة ما يتم استخدامه في اخر وکیل نقل بريد MTA‏ في السلسلة. 
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۳ خادما POP‏ و 111۸8 - وهما بروتوکول مكتب البرید «Post Office Protocol‏ والثاني هو 
بروتوکول الوصول إلى الرسائل عبر الانترنت Internet Message Access Protocol‏ - 
وهما بروتوكولا اتصال حيث يسمحان للبرید الإلكتروني الخاص بالعميل email client‏ والذي يعمل 


على جهازه من مخاطبة الخادم البعيد remote server‏ وذلك لالتقاط البريد الإلكتروني. 


أحيانا جزء من برنامج ما ينفذ بمكونات متعددة. في البيئة المغلقة المصدر؛ Microsoft Exchange‏ يقوم 
بإعطاء كافة المكونات بحيث لا يكون هناك أي خيار اخر. اما في عالم المصدر المفتوح فهناك العديد من 
الخيارات» فبعض خوادم POP / IMAP‏ تنفذ تنسيق قاعدة بيانات database‏ البريد الخاصة بهم للحصول 
على ميزة الأداءء أو أيضا ستحتوي على وكيل تسليم البرید MDA‏ إذا كان ذلك رغبة في قاعدة البيانات 
المخصصة custom database‏ بالإضافة إلى ذلك؛ يستطيع من يستخدم صيغ الملفات القياسية (مثل رسائل 


البريد الإلكتروني ALAS‏ في ملف نصي واحد) ان يختار أي وكيل تسليم بريد .MDA‏ 


يعتبر sendmail‏ أكثر وکیل نقل برید MTA‏ معروف. كما يوجد ايضاً وکیل مشهور آخر وهو Postfix‏ 


حيث وجد ليكون مشابه لوكيل sendmail‏ ولكن أكثر آمانا. 


إذا كنت تستخدم صيغ الملفات القياسية standard file formats‏ لتخزين رسائل البريد الإلكتروني e-mail‏ 
فيمكن لوكيل نقل البرید MTA‏ الخاص بك أيضا ارسال البريد. هناك ايضا tprocmail‏ والذي يتيح لك تصفية 


filter‏ مخصصة لمعالجة البرید وتنظیمه. 


Cyrus IMAP مشهور بسبب سهولة استخدامه وصیانته المنخفضة.‎ POP / IMAP هو خادم‎ Dovecot 


هو خیار آخر. 


بعد ذلك مشاركة الملف» في مجال مشاركة الملفات فان الفائز بلا منازع هو سامبا cus. Samba‏ بسمح لجهاز 
لینکس Linux machine‏ لیظهر Jes «iS‏ ویندوز Windows machine‏ وبذلك تتم مشاركة الملفات 
share files‏ في مجال Windows‏ سامبا Samba‏ بنفذ يتمم دور مکونات الخادم» مثل جعل الملفات متاحة 
للمشاركة وکذلك بعض مهام الأخرى لخادم ویندوز Windows server roles‏ نقطة أخيرةء یقوم سامبا 


بعملية انهاء العمیل client end‏ حتى لا بستهلك جهاز لینکس قد حصة نظام ویندوز الخاصة بمشاركة الملفات. 
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إذا کان لديك أجهزة آبل على الشبكة فان مشروع Netatalk‏ یجعل جهاز لینکس الخاص بك یتصرف كما انه 


.Apple file server خادم ملف أبل‎ 


يطلق على بروتوكول مشاركة الملفات الأصلي لنظام UNIX‏ اسم نظام ملفات الشبکة Network File‏ 
System — (NFS)‏ وعادة ما يكون نظام NFS‏ جزءا من النواة ckernel‏ مما يعني أن نظام الملفات عن 
بعد remote file system‏ يمكن ترکیبه مثل القرص العادي» مما يجعل الوصول إلى الملفات مباشر ومتاح 


لتطبیقات أخرى. 


كلما كبرت شبكة الحاسب الخاصة بك كلما احتجت إلى وجود مرجع .directory‏ ویطلق على أقدم مرجع 
directory‏ نظام أسماء المجال Domain Name System- (DNS)‏ والذي يستخدم لتحويل اسم مثل 
.لال ۷ إلى عنوان [P‏ كالتالي ۸۱۰۰,۱۰۰٦۱۹۲۱۱ء‏ وهو معرف فريد لهذا الجهاز على 
شبكة الانترنت. كما يحتوي نظام DNS‏ على معلومات عالمية مثل عنوان وكيل Ji‏ البرید MTA‏ لاسم مجال 
معين. وهناك منظمات تدير خادم 0115 خاص بهاء بغرض استضافة الأسماء وأيضا ليكون بمثابة دليل داخلي 
internal directory‏ للخدمات. The Internet Software Consortium-(ISC)‏ تحفظ تقریبا جميع 


خوادم DNS‏ الأکثر شعبيةء وتسمی bind.‏ وذلك على اسم العملية التي تقوم بتشغيل الخدمة. 


نظام أسماء المجال DNS‏ يركز بشكل كبير على أسماء أجهزة الحاسب وعناوين IP‏ والتي ليس من السهل البحث 
عنها. ظهرت مراجع directories‏ أخرى تقوم بتخزين المعلومات الأخرى مثل حسابات المستخدمين والأدوار 
الأمنية. بروتوكول الوصول الخفيف إلى الدلیل — Lightweight Directory Access Protocol‏ 
(LDAP)‏ الدليل الأكثر شيوعا والذي يدير أيضا دليل مايكروسوفت النشط Microsoft's‏ 
7 . في LDAP‏ يتم تخزين أي كائن object.‏ في شجرة ومكان هذا الكائن يمكن أن يستخدم 
لاستخلاص المعلومات حول الكائن بالإضافة إلى ما تم تخزينه مع الكائن نفسه. على سبيل المثال؛ يمكن تخزين 
مسوول لينكس في فرع من شجرة يسمى "قسم تقنية المعلومات" ء الفرع السابق موجود تحت فرع يسمى 
"العمليات". وبهذا التسلسل نستطيع ايجاد كل أعضاء الجهاز الفني من خلال البحث ضمن فرع قسم تقنية 


المعلومات. هنا OpenLDAP‏ هو اللاعب المهيمن. 
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جزء اخير من البنية التحتية للشبكة هو بروتوکول التكوين الديناميكي للمضیف Dynamic Host‏ 
Ge Configuration Protocol — (DHCP)‏ یقلع boots up‏ جهاز الحاسب فانه یحتاج إلى عنوان 
[P‏ للشبكة المحلية Local Network‏ بحيث يمكن تحديده بشکل فريد. وظيفة DHCP‏ هي الاستماع للطلبات 
وتعيين عناوين شاغرة من تجمع البروتوكول .DHCP pool‏ ايضا تحتفظ The Internet Software‏ 


DHCP ISC e: Consortium - (ISC)‏ وهو اللاعب الأكثر شيوعا هنا. 


قاعدة البیانات database‏ تخزن المعلومات stores information‏ وتسمح باسترجاعها والاستعلام عنها 
بكل سهولة. قواعد البیانات الأكثر شعبية هنا هي PostgreSQL s MySQL‏ . تستخدم لغة تسمی لغة 
الاستعلام الهيكلية Structured Query Language - (SQL)‏ على قاعدة بیانات بها أرقام مبیعات أولية 


وذلك من أجل إعداد تقریر بالمبیعات الإجمالية حسب ما هو مطلوب كمبيعات منتج معين أو مبيعات لتاريخ محدد. 
۲,۲,۲ تطبيقات سطح المكتب 


نظام لينكس يحتوي على مجموعة كبيرة من تطبيقات سطح المكتب. يمكنك أن تجد العاب تسلية وتطبيقات إنتاجية 
وأدوات إبداعية وأكثر من ذلك. هذا القسم مجرد عرض عام لما يوجد في الساحة؛ مع التركيز على البرامج الاكثر 


أهمية على حسب وجهة نظر معهد لینکس المهني Linux Professional Institute LPI‏ 


أولا سنستعرض بيئة الجهاز المكتبي قبل النظر في التطبيقات الفردیةء يعمل نظام لينكس المكتبي Linux‏ 
0 بنظام يسمى نافذة (X-Window) X‏ والمعروف أيضا باسم X11‏ خادم لينكس X11‏ هو X.org‏ 
يوفر وسيلة للبرامج تمكنها من العمل في الوضع الرسومي graphical mode‏ واستقبال المدخلات من لوحة 
المفاتیح keyboard‏ والفأرة mouse‏ يتم التعامل مع النوافذ والأيقونات من خلال جزء برمجي اخر يسمى 
مدير النوافذ window manager‏ أو بيئة الجهاز المكتبي desktop environment‏ مدير النافذة 
window manager‏ برنامج يقدم كود لعمل القوائم والتحكم في نوافذ التطبيقات الموجودة على شاشة 
سطح المكتب. بيئة سطح المكتب لها طبقات؛ وكل طبقة تقدم مميزات مثل شاشة تسجيل الدخول والجلسات ومدير 
الملفات والمرافق utilities‏ الأخرى. وخلاصة القول انه يمكن تحويل محطة عمل لينكس النصية إلى جهاز 


مكتبي رسومي وذلك بإضافة نافذة X‏ ثم اختيار إما بيئة مكتبية أو مدير النافذة. 
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والان نتوسع في مدير النافذة» يتشمل مدير النافذة على التطبیقات Compiz‏ و FVWM‏ والتنوير 
۲۶ بینات الجهاز المكتبي الرئيسية هي KDE‏ و GNOME‏ وكلاهما له مدير نافذة خاصة 
به. کل من KDE‏ و GNOME‏ مشاریع كاملة مع كمية هائلة من البرامج التي بنيت لأجلهماء والاختيار عادة 


فروسي کزان اتی السك 


ننتقل بعد ذلك إلى التطبيقات الانتاجية الأساسية basic productivity applications‏ مثل معالج النصوص 
وجداول البيانات وعارض الشرائح فإنها موجودة على شكل مجموعة ALIS‏ وتسمی بجناح المکتب Office‏ 


«suite‏ لکن يبقى مايكروسوفت أوفيس Microsoft Office‏ اللاعب المهيمن فی السوق. 


يقدم برنامجي آوبن أوفيس OpenOffice‏ (ویسمی آحیانا (OpenOffice.org‏ وبرنامج LibreOffice‏ 
مجموعة مکتب ALAS‏ بما في ذلك أداة للرسم والمتوافقة مع Microsoft Office‏ سواء من حيث الشکل 


والممیزات. هاذان المشروعان هما مثالين عظیمین لتأثیر سياسة المصدر المفتوح. 


والان لنستعرض مزید من التفصیل عن برنامج لیبر آوفیس „LibreOffice‏ في عام ۱۹۹۹ شركة صن 
مایکروسیستمز Sun Microsystems‏ قامت بشراء شركة المانية غامضة نسبیا كانت تعمل على مجموعة 
مکتب office suite‏ لنظام لینکس تحت مسمی ستار آوفیس „StarOffice‏ بعد فترة وجيزة اعادة الشركة 
التسمية واصدرت أوبن أوفيس OpenOffice‏ ويرخصة مفتوحة المصدرء ایضا بقي ستارأوفايس 
6 منتج شخصي للشركة. وفي عام ۲۰۱۰ اشترت شركة آوراکل Oracle‏ شركة صن 
مایکروسیستمز ثم حول المشروع إلى مؤسسة آباتشي Apache Foundation‏ 

شركة آوراکل Oracle‏ لیس لها في دعم مشاریع المصدر المفتوح التي تملكتهاء لذلك وبعد فترة وجيزة من 
الاستحواذ تغير المشروع لیصبح لیبر آوفیس LibreOffice‏ في تلك المرحلة آصبح هناك مجموعتان من الناس 
یطورون نفس البرمجیات. ذهب أكثر الدعم لمشروع لیبر آوفیس LibreOffice‏ ولهذا السبب تم تضمینه 


افتراضیا في العدید من توزیعات لینکس. 


والان ننتقل إلى تصفح شبكة الانترنت» یوجد في عالم لینکس متنافسین رئیسیین هما فایرفوکس Js. s» Firefox‏ 


کروم Ga IS Google Chrome‏ مفتوح المصدر ویمتازان بسرعة العمل وكثرة الممیزات ووجود دعم ممتاز 
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من المطورین. المستعرضان السابقان هما مثال جید على التنوع في المصدر المفتوح. فإدخال التحسينات على 
آحدهما؛ یحفز الفریق الآخر لتقدیم الافضل. ونتیجة لذلك فان شبكة الانترنت لدیھا متصفحین ممتازین للعمل علی 


شبكة الانترنت بافضل شكلء والتي تعمل عبر مجموعة متنوعة من المنصات. 


والان لنتحدث عن البريد الالكتروني» جاء مشروع موزیلا Mozilla‏ من تندربيرد sas «Thunderbird‏ 
نسخة كاملة لعميل البريد الإلكتروني على سطح المكتب. ثندربيرد يتصل بخادم POP‏ أو AMAP‏ وهو يقوم 


بعرض البريد الإلكتروني email‏ محلياء ويرسل البريد الإلكتروني من خلال خادم SMTP‏ خارجي. 


بالإضافة إلى موزيلا Mozilla‏ فهناك عميلي البريد الإلكتروني في جنوم وكيدي GNOME and KDE‏ وهما 
Evolution‏ و KMail‏ . المعيار القياسي Standardization‏ في بروتوكول POP‏ وبروتوكول IMAP‏ 
وفي شكل البريد الإلكتروني المحلي يعني أنه من السهل التبديل بين عملاء البريد الإلكتروني دون فقدان البيانات. 


البرید الإلكتروني بواسطة الويب Web based email‏ هو أيضا خيار آخر. 


أخيرا الأنواع الابداعية. في هذه الفئة Blender a=‏ و GIMP‏ و Audacity‏ والتي تقوم بانشاء أفلام ثلاثية 
البعد 3D-movie‏ ومعالجة الصور ثنائية البعد 20-1013806 ۰ وتحرير الصوت على الترتيب. تلك الأنواع 
لديها درجات متفاوتة من النجاح في الأسواق المهنية. لکن نستطيع القول أن Blender‏ يُستخدم في كل شيء 


بداية من الأفلام المستقلة إلى افلام هوليوود السنيمائية. 
٣‏ ادوات وحدة التحكم 


يظهر في تاريخ تطور يونيكس UNIX‏ تداخل كبير بين مهارات تطوير البرمجیات software‏ 
development skills‏ وإدارة النظم systems administration‏ الأدوات التي تمكنك من إدارة النظام 
لها مميزات لغات الحاسب مثل الحلقات ۰10005 وتستخدم بعض لغات الحاسب على نطاق واسع في انجاز مهام 
ادارة النظم بشكل تلقائي 18515 automating systems administration‏ وبالتالي ينبغي أن تأخذ هذه 
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على المستوی الأساسي» یمکنك التفاعل مع نظام لینکس من خلال القشرة shell‏ حيث لا يهم اذا كنت تحاول 
الاتصال بالنظام عن بعد أو من خلال لوحة المفاتيح المرفقة. وظيفة القشرة shell‏ هي قبول الأوامر 
commands‏ مثل تعدیل الملفات file manipulations‏ وفتح التطبيقات ثم بعد ذلك تمريرها إلى نواة 


لينكس لتقوم بتنفيذها Linux kernel‏ وهنا مثال يبين لنا تفاعل نموذجي مع قشرة لينكس :Linux shell‏ 


:-$ وا‎ -l /tmp/*.gz 


-rw-r--r-- l1 sean root 246841 Mar 5 2013 /tmp/fdboot.img.gz 


:-$ rm /tmp/fdboot.img.gz 


مثال علی أوامر موجهه لقشرة لینکس 


يقوم المستخدم بالتعامل مع موجه الأوامر «prompt‏ والذي ينتهي عادة بعلامة الدولار (8) للإشارة إلى الحساب 
العادي والغير ممیز unprivileged account‏ اما ما يسبق كتابة الأوامر وهو في هذا المثال 
:1062111051 ۰5۷520۳۱۱۱۵ فهي اعدادات الموجه والتي توفر معلومات إضافية للمستخدم. في الشكل 
أعلاه؛ sysadmin‏ هو اسم المستخدم» اما localhost‏ فهو اسم الخاد اما علامة تيلدا - فهي الدليل الحالي 
directory‏ (في يونيكسء الرمز تيلدا 1106 هو رمز مصغر لدليل المستخدم الرئيسي). وسوف نتعرف على 
أوامر لينكس بمزيد من التفصيل في الفصول القادمة» ولكن ولأنهاء شرح المثال السابق» فان الأمر وا یعرض 
قائمة بالملفات؛ حيث يستقبل بعض المعلومات حول الملف؛ وفي السطر الثالث من الشكل تتم إزالة هذا الملف مع 


امر الحذف rm‏ 


توفر قشرة لینکس Linux shell‏ لغة غنية بالتکرار على الملفات dterating over files‏ وميزة تخصیص 
ài;‏ العمل customizing the environment‏ اضافة إلى ذلك فأننا نجد جُمل برمجية syntax‏ مدمجة 
„built-in scripting language‏ على سبیل المثال؛ يمكن کتابة سطر واحد لایجاد الملفات التي تحتوي على 


تطابق لنمط معین؛ واستخراج المعلومات المفيدة من ملف» واخیراً نسخها إلى ملف جدید. 


لینکس یوفر مجموعة متنوعة من القشور shells‏ للاختیار منهاء والاختلاف في الغالب یکون في ماهية الاشیاء 
التي یمکن تخصیصها وکیف بالاضافة إلى نوعية الجمل المضمنة في اللغة. هناك فنتان رئیسیتان هما قشرة 


Bourne shell oss‏ وقشرة LC‏ سمیت قشرة بورن Bourne‏ على اسم مصممهاء اما قشرة © فسبب 
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تسمیتها ان الجُمل البرمجية فيها اخذت الكثير من لغة 6. الجدیر بالذکر ان كلا القشرتين اخترعتا عام ۱۹۷۰. 
في الوقت الحالي توجد إصدارات جديدة لهما هما قشرة الباش Bourne Again Shell (Bash)‏ وقشرة tcsh‏ 
.(tee-cee-shell)‏ الباش Bash‏ هو القشرة الافتراضية التي تأتي مع اغلب النظمء ولكنك تستطیع استخدام 


قشرة tesh‏ إذا كانت هي المفضلة لديك . 


بعض المستخدمون أخذو المميزات المفضلة لهم من قشرتي Bash‏ و tesh‏ وقاموا بصنع قشور اخری» مثل 
قشرة كورن Korn shell (ksh)‏ وايضاً قشرة zsh‏ اختيار القشرة shell‏ في الغالب مسالة شخصية. إذا 
بدأت مع قشرة الباش Bash‏ وتمكنت من التأقلم معها؛ فيمكنك العمل بفعالية على معظم أنظمة لينكس. بعد ذلك 


يمكنك التغيير وتجربة قشور اخرى لمعرفة ما إذا كانت تساعد انتاجيتك. 


بعد ذلك يأتي اختيار برامج تحرير النصوص editors‏ 6]. يستخدم محرر النصوص في وحدة التحكم 
Jai console‏ ملفات التكوين configuration files‏ وبصفة عامة يوجد نوعين رئيسيين من محرري 
النصوص؛ الأول هو فاي vi‏ أو فايم vim‏ والثاني هو إيماكس emacs‏ كلاها يعتبران أداتين قويتين لتحرير 
الملفات النصيةء لكنهما يختلفان في شكل الأوامر وكيفية كتابة الإضافات plugins‏ لهما. الاضافات يمكن أن 
تكون أي شيء من الجمل الواضحة syntax highlighting‏ لمشاريع البرمجيات software projects‏ إلى 


التقویمات السنوية الكاملة integrated calendars‏ 


التعامل مع فايم vim‏ و إيماكس EMACS‏ صعب وله مستويات تعلم مرهقة. لذلك فهما غير مفيدان إذا کان كل 
ما تحتاجه هو تحرير بسيط من ملف نصي صغير. لذلك هنالك برنامجا بيكو pico‏ ونانو nano‏ والموجودان 


في معظم الانظمة (وهذا الأخير هو مشتق من السابق)» ويوفران تحرير نص أساسي فقط. 


حتی إذا اخترت عدم استخدام محرر فاي أا؛ فإنه يجب عليك ان تتعرف عليه لأنه موجود في كل انظمة لينكس. 
الجدير بالذكر انه إذا كنت تريد استعادة نظام لينكس لإصلاحه عن طريق تشغيل أداة استرداد النظام الموزع 


vi فيجب أن يكون لديك المحرر فاي‎ distribution's recovery 


في انظمة التشغيل عادة ما نقوم باضافة البرامج install‏ وتحديثها update‏ أو حتى از التها remove‏ وهذا 


يعني تحميل شفرة المصدر source code‏ ثم بعد ذلك تنصيبها والبناء عليها واخيرا نسخ الملفات على كل 
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نظام. لحسن الحظ هناك توزیعات distributions‏ صنعت حزم packages‏ والتي هي عبارة عن نسخ 
مضغوطة من التطبیق. مدير الحزم package manager‏ يعتني بحفظ مسار الملفات التي تنتمي لحزمة ما 
وایضا تنزیل التحدیثات من خادم بعید یسمی المستودع repository‏ أنظمة Debian ous‏ تشتمل على 
الأدوات dpkg‏ و 301-061 و .apt-cache‏ اما الانظمة المشتقة من ريد هات Red Hat‏ فیوجد فیها 


.yum و‎ 
التطویر‎ cal gal ٤ 


ينبغي ألا تکون متفاجنا عندما تعلم أن مثل هذه البرمجیات (أدوات التطویر) مبنية على إسهامات من المبرمجین» 
وان نظام لینکس Linux‏ لديه دعم ممتاز لتطویر تلك البرمجیات. يتم بناء القشور shells‏ لتکون قابلة للبرمجة 
6 بالإضافة إلى وجود برامج تحریر editors‏ قوية في كل نظام. هناك أيضا العدید من 
آدوات التطویر development tools‏ المتاحة. بالإضافة إلى ان وجود العدید من اللغات الحديثة والتي 


تتعامل مع لینکس على انه أول اهتماماتها. 


Q&A لادخال التعلیمات في‎ programmer وسيلة للمبرمج‎ Computer languages لغات الحاسب‎ ji ji 
إلى مادة بفهمها‎ translated ثم بعد ذلك يتم ترجمتها‎ chuman readable format مقروء للإنسان‎ 
interpreted .compiled أو تجمیع للتنفيذ‎ interpreted الحاسب. اللغات تقع ضمن مجموعتین: تفسیر‎ 
فیقوم بترجمة اللغة بالکامل‎ compiled hly المکتوب إلى كود حاسب يعمل كبرنامج»‎ code. تترجم الکود‎ 


بغرض التنفیذ الفوري. 


سنتحدث الآن عن axe‏ من لغات البرمجة الأولى هي لغة الترجمة ^us (C compiled language) C‏ قد 
تم کتابة نظام التشغیل لینکس Linux‏ بهذه اللغة. الفاندة الرئيسية من © أن مفرداتها وخرانطها مرتبطة ارتباطا 
وثیقا بکود الالة» بحیث ان أي مبرمج ماهر یستطیع AUS‏ كود code‏ صغیر وفعال. وکان ذلك مهم جدا عندما 
کانت ذاکرة الحاسب computer memory‏ تقاس بالكيلو بايت» حتى أيضا مع أحجام الذاكرة الكبيرة الیوم؛ 


لغة © لا تزال مفيدة لكتابة الاکواد التي يجب أن تعمل بسرعة مثل نظام التشغیل, 
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وقد تم توسیع لغة © على مر السنین؛ والدلیل على ذلك هو لغة C++‏ الذي تقوم بدعم الکائنات object‏ 
support‏ وإضافتها إلى لغة C‏ وهو نمط مختلف من البرمجةء دلیل اخر هو لغة © Objective‏ والتي أخذت 


اتجاه آخر وئستخدم بشکل کبیر في منتجات بل „Apple‏ 


اللغة الثانية وهي آیضا مهمة هي لغة جافا Java‏ والتي تأخذ ادوار مختلفة في نهج الترجمة. Yad‏ من الترجمة 
إلى كود الآلة» فأن جافا Java‏ تتخیل وجود معالج افتراضي hypothetical CPU‏ وتسمية آلة جافا الافتراضية 
(JVM) Java Virtual Machine‏ وبالتالي تتم ترجمة کل الکود لذلك المعالج. بعد ذلك یقوم کل حاسب 
مضیف host computer‏ بتشغیل برنامج JVM‏ لیقوم بتر جمة تعلیمات JVM‏ وتسمی بایت كود bytecode‏ 


إلى تعلیمات رئيسية .native instructions‏ 


قد یظن البعض أن الترجمة الاضافية السابقة تجعل JAVA‏ بطيء. ولکن في الحقيقة JVM‏ بسیط بحیث يتم 
تنفیذه بشکل سریع وموئوق على أي آلة» ابتداء من جهاز حاسب قوي وانتهاء بجهاز منخفض الطاقة موصول 
بالتلفاز. الجدیر بالذکر انه یمکن تشغیل ملف مترجم جافا compiled Java file‏ على أي جهاز حاسب يحوي 


.JVM 


فائدة أخرى من الترجمة compiling‏ إلى مكان وسطي intermediate target‏ هي أن JVM‏ يمكن أن 
یوفر خدمات للتطبيقات التي عادة لا تكون متاحة على المعالج. إن حجز ذاكرة واسنادها إلى برنامج هي عملية 
معقدة» والحل هنا یکمن في استخدام VM‏ ل. وهذا يعني أيضا أن واضعي JVM‏ ركزوا على تحسينات JVM‏ 


ككل» لذلك أي تقدم يُصنع يصبح متوفر على الفور للتطبيقات. 


من ناحية أخرىء لغة التفسير interpreted‏ يتم تحويلها إلى كود الاله للتنفيذ. الحاسب القوي جدا ينهك من 
هذا ولكن يمكن ان يعوضه من خلال زيادة الإنتاجية وتحقيق مكاسب من خلال عدم الحاجة للتوقف عن العمل 
للترجمة. تميل لغات التفسير Interpreted languages‏ أيضا لتقديم المزید من المزايا عن لغات الترجمة 
compiled languages‏ وهذا يعني أن تقليل الكود مطلب رئيسي. مترجم اللغة نفسها عادة ما يكون مكتوب 
بلغة أخرى مثل C‏ وأحيانا جافا. وهذا يعني أن Ax]‏ التفسير يتم تشغيلها على آلة جافا الافتراضية JVM‏ والتي 


تترجم إلى كود الاله في وقت الت لتشغيل. 
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ثالثا لغة Perl Jos‏ هي لغة تفسير ضعت في الاصل لمعالجة النص. على مر السنين اکتسبت هذه اللغة 
استحسان مسؤولي الانظمة لأنها في تحسن مستمر. تستخدم لغة بيرل في كل شيء من التشغيل الالي إلى بناء 


تطبيقات الويب. 


رابعاً PHP‏ وهي لغة تم بناؤها في الأصل لإنشاء صفحات الويب الديناميكية. تتم قراءة ملف PHP‏ من قبل 
خوادم الويب Jis web servers‏ أباتشي Apache‏ توجد في ملف PHP‏ علامات خاصة؛ تشير إلى أن 
أجزاء من الكود code.‏ يجب أن تفسر على أنها تعلیمات instructions‏ ليقوم بعد ذلك خادم الويب بجمع 
أجزاء الملف مع بعضها البعض وإرساله إلى متصفح الويب web browser‏ الميزة الرئيسية في لغة PHP‏ 
هي أنها سهلة التعلم ومتوفرة تقريبا على أي نظام. وبسبب هذا بُنيت العديد من المشاريع بواسطة PHP‏ ومن 
الأمثلة البارزة مدونة ورد برس WordPress (blogging)‏ وايضا (monitoring) cacti‏ وأجزاء من 


موقع التواصل الاجتماعي الشهير الفيسبوك facebook‏ 


خامساً روبي Ruby‏ وهي لغة أخرى تأثرت بلغة Perl Jos‏ والقشرة Shell‏ بجانب العديد من اللغات 
الأخرى. لکن هذه اللغة تمتاز بمقدرتها على تحويل مهام البرمجة المعقدة إلى سهلة نسبیاء ومع تضمين نافذة 
Rails framework‏ تصبح الاختيار الأمثل لبناء تطبيقات الويب المعقدة. روبي RUDY‏ هي أيضا اللغة 
المحركة لكثير من أدوات التشغيل الآلي الرائدة مثل Chef‏ و «Puppet‏ ميزة أخرى لهذه اللغة انها تسهل إدارة 
الاعداد الكبير من أنظمة لينكس. 


سادساً بایشون Python‏ وهي لغة برمجة شائعة الاستخدام ايضا. مثل لغة روبي Ruby‏ فأن بايثون تجعل 
المهام المعقدة أسهل» ولها نافذة تسمى Django‏ والتي تجعل بناء تطبيقات الويب امراً Sua‏ للغاية. بايثون 


0 لديها قدرات معالجة إحصائية ممتازة وهي المفضلة في الأوساط الأكاديمية. 


خلاصة القول ان اللغة هي مجرد أداة تجعل من السهل أن نقول للحاسب ما نريد فعله. وتحتوي اللغات على 
مجموعة من المكتبات» ويمكن تلخيص دور المكتبات على انها تقوم بجمع المهام المشتركة library bundles‏ 
common tasks‏ في حزمة واحدة تستخدم من قبل المطور. ImageMagick‏ هي إحدى هذه المكتبات» 
والتي تتيح للمبرمجين تعديل الصور في الكود .Code‏ وتأتي مع بعض أدوات سطر الأوامر command‏ 
line tools‏ والتي تُمكنك من معالجة الصور من القشرة shell‏ والاستفادة من قدرات البرمجة هناك. 
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551 هي مکتبة تشفیر التي يتم استخدامها في كل شيء من خوادم الشبكة إلى سطر الأوامر. وهي توفر 


واجهة موحدة بحيث بمکنك إضافة الترميز cryptography‏ في لغة بيرل „Perl‏ 


وفي المستویات الأخيرة نجد مكتبة ©. وهي توفر مجموعة أساسية من الوظائف مثل العرض والقراءة والكتابة 


من وعلی الملفات والتي تستخدم من قبل التطبيقات واللغات الأخرى على حد سواء. 


عندما نتحدث عن شراء البرمجيات هناك ثلاثة عناصر متميزة: 


4 الملكية Ownership‏ من يملك الملكية الفكرية وراء البرنامج؟ 
4 تحويل الأموال :Money transfer‏ الكيفية؟ 
& الترخيص Licensing‏ على ماذا ستحصل؟ ماذا يمكنك أن تفعل بالبرنامج؟ يمكنك استخدامه على 


حاسب واحد فقط أو يمكنك إعطائه لشخص آخر؟ 


في معظم الحالات. ملكية البرنامج تبقی مع الشخص أو الشركة التي صنعته» Lf‏ المستخدمون فيتم منحهم ترخيص 
لاستخدام البرنامج وهذا حق مكفول في قانون حق الملكية. اما النقطة الثانية وهي تحویل الأموال فهي تعتمد على 
نموذج العمل للصانع. وأخيرا تراخيص البرنامج وهي التي تميز حقا بين البرمجيات مفتوحة المصدر والبرمجيات 


m 


شركة مايكروسوفت 535 Microsoft Windows‏ تمتلك الملكية الفكرية. اتفاقية ترخيص المستخدم End‏ 


User License Agreement - ( AULE)‏ هي وثيقة قانونية خاصة يجب عليك الموافقة عليها بالنقر 


authorized من خلال القنوات المصرح بها‎ binary copies وتقوم بتوزيع نسخ ثنائية‎ source code 
فأنه یسمح لك بتثبیت البرنامج‎ consumer products بالنسبة لمعظم المنتجات الاستهلاكية‎ 5 


على جهاز حاسب واحد فقط؛ وأیضا لا ُسمح بعمل نسخ آخری غير النسخة الاحتياطية. وأخیرا فلا يسمح لك 
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بتغيير هندسة البرنامج. لذلك فأنت تدفع لنسخة واحدة من البرنامج فقط ولن تحصل الا على تحديثات بسيطة له 


من غير أي ترقية كاملة. 


في الجهة الأخرىء asd‏ ان لینکس Linux‏ مملوكة من قبل لينوس تورفالدس Linus Torvalds‏ والذي وضع 
الكود الذي قام ببرمجته تحت ما يسمي برخصة جنو العمومية الإصدار الثاني GNU Public License‏ 
version 2 - (GLPv2)‏ يعني هذا الترخيص إن كود المصدر source code‏ يجب أن يكون متاحا لأي 
شخص؛ كما يسمح له بإجراء أي تغييرات أو تعديلات يريد ادخالها عليه. التحذير الوحيد أنه إذا قمت بعمل 
تغييرات ثم قمت بتوزيعها فأنه يجب عليك وضعها تحت نفس الترخيص حتى يتسنى للآخرين الاستفادة منها. 
تنص رخصة GLPv2‏ أيضا على أنه لا يُسمح لك بأخذ تكاليف لتوزيع كود المصدر source code‏ أكثر 


من تكاليفك الفعلية للقيام بذلك (مثل نسخها إلى الوسائط القابلة للإزالة). 


بشكل عام عند إنشاء create‏ عمل ما يمكنك الحصول على الحق في تقرير كيفية استخدام ذلك العمل وتوزيعه 
used and distributed‏ كيف تشاء. البرمجيات الحرة والمفتوحة المصدر Free and Open Source‏ 
Software - (FOSS)‏ تشير إلى التخلي given up‏ عن هذا الحق والسماح بعرض كود الرئيسي للبرنامج 
وهو كود المصدر source code‏ وأيضا القيام بعملية إعادة التوزيع redistribute‏ لذلك العمل. وهذا ما 
فعله لينوس تورفالدس Linus Torvalds‏ مع لينكس» على الرغم من أنه created. Usi‏ لينكس الا انه يمكن 
لأي كان استخدامه بلا مقابل» وذلك بسبب تخليه عن حقه فيه right given up‏ من خلال وضعه تحت ترخيص 


.GLPv2 


تراخيص البرامج هي قضية سياسية «political issue‏ وينبغي ألا تكون متفاجنا بوجود العدید من الآراء 
المختلفة حولها. وهو ما سبب ظهور منظمات قامت بطرح رخص خاصة بھا والتي تتضمن عرض لوجهات 
نظرهاء ومع وجود ذلك العدد من التراخيصء أصبح اختيار ترخیص موجود لبرنامج ما أسهل من انشاء ترخیص 
جدید. على سبيل المثال» أوجدت الجامعات مثل معهد ماساتشوستس للتكنولوجيا (MIT)‏ وجامعة كاليفورنيا 
University of California‏ تراخيص لمشاريعهم Jia‏ مؤسسة أباتشي „Apache Foundation‏ الجدير 
بالذكر أن مجموعات مثل مؤسسة البرمجيات الحرة Free Software Foundation‏ قد صنعت تراخيص 


خاصة بها لتعزيز أجندتها أيضا. 
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۲۱ ,۲ مؤسسة البرمجیات الحرة و المصدر المفتوح 


في alle‏ المصادر المفتوحة هناك مجموعتین يمكن اعتبارها القوی والأكثر تأثيراء الأولى هي مؤسسة البرمجیات 
الحرة Free Software Foundation — (FSF)‏ والثانية Open Source Initiative — (OSI)‏ 


وهي مبادرة المصدر المفتوح. 


تأسست مؤسسة البرمجيات الحرة عام ۱۹۸۰ء وذلك من قبل ريتشارد ستالمان Richard Stallman‏ 
(RMS)‏ هدف هذه المؤسسة هو تعزیز البرمجيات الحرة Software‏ ۳۲۵۵. البرمجيات الحرة لا تشير إلى 
سعر البرنامج بل إلى الحرية في تبادل ودراسة وتعديل التعليمات البرمجية للكود المصدر underlying‏ 

.source code‏ ومن وجهة نظرها (FSF)‏ أن البرمجيات الاحتكارية proprietary software‏ (التي 
توزع بموجب رخصة مغلقة المصدر) سيئة. كما تطالب مؤسسة (FSF)‏ أن تكون البرمجيات المرخصة AL‏ 


للتعديل modifications‏ وبعد ذلك تأتي مشاركة هذه التعديلات أو التغييرات وهو ما يسمى بفلسفة النسخة 


„copyleft المتروكة‎ 


تعارض مؤسسة البرمجيات الحرة (FSF)‏ براءة اختراع البرمجيات «software patents‏ وتعمل كمراقب 
عام للمنظمات المعيارية «standards organizations‏ وتقوم بنشر أي انتهاك لمعايير البرمجيات الحرة 
بواسطة مواد مثل إدارة الحقوق الرقمية Digital Rights Management - (DRM)‏ التي يمكن أن تقيد 


ما تقدمه من خدمات. 


وضعت (FSF)‏ مجموعة من التراخيص الخاصة بها مثل GLPv35 GLPv2‏ وترخیص GPL‏ الصغير 
Lesser GPL licenses‏ الإصدارات Y‏ و (LGPLv35 LGPLv2) ٣‏ الترخص الصغير lesser‏ 
Jis licenses‏ الترخيص العادي الا أنه يتضمن أحكاما ضد البرامج غير المجانية .non-Free Software‏ 
على سبيل المثال» تحت مظلة الترخیص 3]0۷2) فانه لا يمكنك إعادة توزيع البرمجیات التي تستخدم مكتبة ذات 


مصدر مغلق مثل برنامج تشغیل الأجهزة non-Free Software‏ ولكن الترخص الصغير يسمح بذلك. 


التغييرات بين الاصدار Y‏ و ۳ تتمحور- إلى حد کبیر حول استخدام البرمجيات الحرة في جهاز مغلق closed‏ 


hardware device‏ والذي & باسم |Tivoization‏ تيفو TiVo‏ هي الشركة التي cuan‏ مسجل الفيديو 
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الرقمي التلفزيوني television digital video recorder‏ على أجهزتهم واستخدموا لینکس کأساس 
لبرامجهم. بموجب ترخیص GLPV2‏ نشرت تيفو TiVo‏ كود المصدر source code‏ لنسخة من لينكس» 
ولکن آجهزتهم لم تقم بتشغيل أي تعديل ثناني „binaries‏ وهذا بنظر موسسة البرمجيات الحرة (FSF)‏ 
یتعارض مع روح 61۳۷2 لذلك أضافوا بندا محددا إلى الإصدار ۳ من الرخصة. وتوصل لينوس تورفالدس 


.)3 210/2 إلى حل مع تيفو بشأن هذه المسألة واختارت البقاء مع ترخيص‎ Linus Torvalds 


والآن لنتحدث عن المجموعة الثانية في عالم المصادر المفتوحة وهي مبادرة المصدر المفتوح» تأسست مبادرة 
المصدر المفتوح Open Source Initiative‏ في عام ۱۹۹۸ من قبل بروس بيرينز Bruce Perens‏ 
وإريك ريموند (ESR) Eric Raymond‏ وهم يعتقدون أن البرمجيات الحرة Free Software‏ هي 
مشحونة جدا بالسياسة» وأنها آقل صرامة مما يجب أن تكون» وتحديدا حول نقطة الحقوق المتروكة copyleft‏ 
في تراخيص البرمجيات الحرة (FSF)‏ ويرى أعضاء (OSI)‏ انه ينبغي أن يكون المصدر source‏ متاح 
بحرية» وانه يجب الغاء أي قيود موضوعة على استخدام البرمجيات بغض النظر عن الاستخدام المقصود. وبعكس 
(FSF)‏ فان Y (OSI)‏ يوجد لديها مجموعة تراخيص مختلفة ولكنها عوضا عن ذلك تحتوي على قائمة بها 
مجموعة من المبادئ واضيفت لها تراخيص أخرى توافقت مع مبادئھمء وسميت بتراخيص المصدر المفتوح 
Open Source licenses‏ لذا البرامج التي تتفق مع رخص المصدر المفتوح Open Source license‏ 


هي برمجيات مصدر مفتوح .Open Source Software‏ 


بعض رخص المصدر المفتوح تأتي من تراخيص عائلة BSD‏ وهي أبسط بكثير من تراخيص GPL‏ حيث 
أنها تسمح بإعادة توزيع المصدر والنظام الثنائي source and binaries‏ بشرطينء الأول هو أن تبقى 
إشعارات حقوق النشر copyright‏ والثاني ألا لمح أن منشئ الإصدار الأصلي في النسخة التي عدلتها. وبعبارة 
أخرى اعمل ما تريد في هذا البرنامج» فقط لا تقول أنك كتبته. وتتفق رخص معهد ماساتشوستس للتکنولوجیا 
۲ مع هذا الفكر ولكنه مكتوب لديهم بصيغة اخرى. 

تراخيص مؤسسة البرمجيات الحرة FSF‏ مثل 691۳۷2 هي تراخيص مفتوحة المصدر. ومع ذلكء فان العديد 


من التراخيص المفتوحة المصدر مثل  BSD‏ ومعهد ماساتشوستس للتکنولوجیا MIT‏ لا تحتوي على أحكام الحقوق 


المتروكة copyleft‏ وبالتالي فهي مسألة غير مقبولة لمؤسسة البرمجيات الحرة FSF‏ ويطلق على هذه 


AW‏ اساسیات لینکس 


الرخص المتساهلة permissive‏ تراخيص للبرمجیات الحرة free software licenses‏ وذلك لأنها 
متساهلة تجاه كيفية إعادة توزيع البرمجیات. لذلك تستطیع أخذ البرامج المرخصة من BSD‏ وإدراجها في منتجات 


البرمجيات المغلقة طالما أنك اعطيت الإسناد الصحيح. 


بدلا من التدقيق على التفاصيل الصغيرة بين المصدر المفتوح OSI‏ والبرمجيات الحرة FSF‏ بدأ المجتمع 
بالإشارة إلى كل ذلك بمسمى برمجيات المصدر الحر والمفتوح Free and Open Source software‏ 
(FOSS)‏ الكلمة الإنجليزية "مجانا" free‏ والموجودة في المسمى FOSS‏ يمكن أن تكون مربكةء حيث أنها 
تعني مجانا بلا مقابل كما هو الحال في وجبة غداء" (بدون اي تكلفة) أو تعني حر كما في الخطاب (دون أي 
قيود). وقد أدى هذا الغموض إلى إدراج كلمة ليبر libre‏ للإشارة إلى التعريف الأخير. وبالتالي» وفي نهاية 
المطاف أصبح الاسم كما يلي البرمجيات المجانية / الحرة المفتوحة المصدر Free/Libre/Open Source‏ 


Software - (FLOSS) 


رغم أن هذه الشروط تبدو متآلفة» الا آنها تخفي الكثير من اختلافات الفكر بين المدرستين السابقتين. وخلاصة 
القول؛ عند استخدام برامج FLOSS‏ فأنك غير ملزم بدفع ثمنهاء كما ويمكنك إعادة توزيع تلك البرامج دون 


أي قيود. 


٣‏ أنظمة التراخيص الأخرى 


تراخيص FOSS‏ تتعلق معظمها بالبرامج. وقد وضع الناس اعمال مثل الرسم والخطط ضمن ترخيص FOSS‏ 


ولكن لم يكن هذا هو القصد. 


عند وضع بردامج ما فى المجال شب فهاذا يعني أن کلب البرنامج قد تخلی عق جمیع التطرق بما في ناف 
حقوق الملكية copyright‏ ویعتبر هذا في بعض آلبلدان هو التصرف الطبيعي عندما یتم العمل من قبل وكالة 
حكومية. وفي بلدان اخری تتحول حقوق الطبع والنشر والملكية إلى حق عام في حالة وفاة المؤلف وانقضاء فترة 


انتظار طويلة. 


اساسیات لینکس 


أنشأت منظمة المشاع الابداعي Creative Commons - (CC)‏ تراخیص المشاع الابداعي Creative‏ 


Commons Licenses‏ التي تحاول معالجة النوايا وراء رخص البرمجيات الحرة المفتوحة المصدر 


FOSS‏ للكيانات الغیر برمجية non software entities‏ ويمكن أيضا ان تستخدم تراخيص CC.‏ لتقييد 


الاستخدام التجاري اذا كان هذا هو رغبة صاحب حقوق الطبع والنشر copyright holder‏ ويمكن تلخيص 


تراخیص 66 کالتالي: 


ر 
وه 


وه 


وه 


وه 


إسناد Attribution - (CC-BY)‏ : مثل الكثير من رخص BSD‏ بخولك CC-BY‏ من استخدام 
اي محتوی مع ذکر صاحب حقوق الطبع والنشر. 

إسناد المشاركة بالمثل Attribution ShareAlike - (CC BY-SA)‏ : وهي نسخة متروكة 
الحقوق copyleft‏ ولكن في ترخيص الاسناد. وهي تنص على أن العمل المشتق يجب أن يكون مشترك 
تحت نفس الترخيص وذلك يشبه إلى حد كبير افكار البرمجيات الحرة .Free Software ideals‏ 
إسناد -y‏ للاشتقاق Attribution No-Derivs -(CC BY-ND)‏ : ويعني امكانية إعادة توزيع 
المحتوى تحت نفس شروط CC-BY‏ ولكن بدون أي تغيير. 

إسناد غير تجاري Attribution-NonCommercial - (CC BY-NC)‏ : وهو مشابه تماما 
لإسناد CC BY‏ ولكن Y‏ يحق فيه استخدام المحتوى لأي اغراض تجارية. 

إسناد غير تجاري للوثائق الحرة Attribution-NonCommercial (CC-BY-NC-SA)‏ 
-ShareAlike‏ وهو مبني على ترخيص CC BY-NC‏ ولكن يستلزم أن تكون التغييرات متاحة 
للمشاركة تحت نفس الترخيص. 

اسناد - غير تجاري - غير مشتق Attribution-NonCommercial (CC-BY-NC-ND)‏ 
-No-Derivs‏ : ويعني أنه يمكن مشاركة المحتوى ليتم استخدامه لأغراض غير تجاريةء ولكن بدون 
تغيير المحتوى. 

لا للحقوق المحفوظة No Rights Reserved - (CCO)‏ : هذه هي نسخة ترخیص المشاع 


الإبداعي بالمجال العام. 
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الرخص أعلاه يمكن تلخيصها على النحو التالي بالمثل ShareAlike‏ أو «no restrictions 253 os%‏ وهل 


يسمح فيها أو لا بالاستخدام التجاري أو الاشتقاقات. 
٢ل‏ النماذج التجارية للمصدر المفتوح 
إذا كنت تعطي البرنامج مجانا فکیف يمكنك كسب المال؟ 


إن أبسط طريقة لكسب المال هو عن طريق بيع الدعم support‏ أو الضمان warranty‏ للبرمجيات. ويمكن 
أيضا كسب المال عن طريق تثبيت installing.‏ البرنامج للآخرين» والمساعدة في حل المشاكل «problems‏ 


أو تحديد الخلل fixing bugs‏ مقابل المال فتصبح استشاري consultant‏ فعال. 


كما يمكنك أيضا فرض رسوم على خدمة service‏ أو الاشتراك subscription‏ بالبرنامج. مشروع مسجل 
الفيديو الرقمي ذو المصدر المفتوح Open Source MythTV digital video recorder project‏ هو 
مثال ممتاز على ذلك. البرنامج نفسه مجاني؛ ولكن یتم الدفع لتوصیله بقائمة جهاز التلفاز لمعرفة أوقات البرامج 


من وسائل كسب المال أيضا إعطاء مجموعة أجهزة package hardware‏ أو اضافة برامج مغلقة المصدر 
closed source‏ لبيعها Uis‏ إلى جنب مع البرمجيات الحرة Free software‏ الأجهزة والانظمة المدمجة 
Appliances and embedded systems‏ التي تستخدم نظام التشغيل لينكس يمكن تطويرها وبيعها 
ايضا. العديد من جدران الحماية firewalls:‏ الاستهلاكية وأجهزة الترفيه entertainment devices‏ تتبع 


هذا النموذج. 


يمكنك أيضا تطوير develop‏ برمجيات المصدر المفتوح open source software‏ كجزء من وظيفتك. 
إذا قمت بإنشاء أداة لتسهيل عملك فستكون قادر على إقناع صاحب العمل بجعلها ذات مصدر مفتوح. أيضا يمكن 
ان تعمل بوظيفة بمقابل مالي ولكنك تعمل على برنامج ذو ترخيص مفتوح المصدرء فعملية نشره للمستخدمين 


تسمح بالمساعدة في حل نفس مشكلة. 
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في عام ۱۹۹۰ء کان جیرالد کومز Gerald Combs‏ يعمل على موفر خدمة الانترنت Internet service‏ 
provider — (ISP)‏ وبدأ بكتابة أداة تحلیل الشبكة network analysis tool‏ وذلك لأن الأدوات الممائلة 
في ذلك الوقت كانت مكلفة للغاية. وقد ساهم أکثر من ۰ شخص إلى الآن في المشروع المسمی .Wireshark‏ 
والآن يعتبر ذلك المشروع أفضل حتى من العروض التجارية الموجودة» وهو ما أدى إلى قيام شركة تشكلت حول 
جيرالد لدعم aie Wireshark‏ بيع المنتجات والدعم أصبح المشروع أكثر فائدة. واخيراً تم شراء هذه الشركة 


من قبل منتج شبكة معروف ليدعم تطور البرنامج. 


شركات أخرى حصلت على قيمة هائلة من برامج المصدر المفتوح» حيث انهم وجدوا أنها تستحق توظيف 
أشخاص للعمل على عليها بدوام كامل. وكمثال على ذلك؛ فقد قامت شركة جوجل Google‏ صاحبة محرك 
البحث search engine‏ بتوظيف كاتب لغة البرمجة بایٹون uis «Python‏ لينوس تورفالدس نفسه Linus‏ 
Torvalds‏ تم توظيفه من قبل مؤسسة لينكس Linux Foundation‏ للعمل على مشروع لينكس. شركة 
الهاتف الأمريكية AT 8 T‏ حصلت على قيمة مماثلة من خلال مشروعي Ruby‏ و Rails‏ والخاص بدليل 


الهاتف الاصفر الخاص Yellow Pages ee‏ وقد وظفوا مجموعة من الموظفين فقط للعمل عليها. 


طريقة نهائية لجني المال بشكل غير مباشر من خلال المصادر المفتوحة وهي أنها وسيلة ممتازة للحكم على 
المهارات. فهناك فرق بين ان تقول عن مميزات ادائك وبين ان تنشر عملك وتشاركه ليسمح للعالم بمعرفة نوعيته 
بمن فيهم رؤساء عمل محتملين. وبالمثل وجدت الشركات التي تفتح الأجزاء الغير الهامة من برامجها الداخلية 


انها تجذب اهتمام الجميع. 
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الفصل الثالث - استخدام لینکس 


Using Linux 


A‏ اساسیات لینکس 
۲,۱ مقدمة 


قبل أن تتمکن من أن تصبح مسوول فعال لانظمة لینکس «effective Linux systems administrator‏ 
يجب أن تکون قادرا على استخدام جهاز لینکس المكتبي ۰065/00 وان تکون محترف مع المعلومات الأساسية 
basic Information‏ ومهارات تکنولوجیا الاتصالات «Communication Technology - (ICT)‏ 
لأنها سوف تساعدك عند التعامل مع المستخدمين ۰86۲5 ومما لا شك فيه أن التعمق في استخدام لينكس سوف 
يساعدك على تحسين مهاراتك بسرعة أكبر. وعلاوة على ذلك« عمل مدير نظم systems administrator‏ 
لا تقتصر على الإلمام بأعمال الخادم «server work‏ بل يمتد ليشمل العمل على البريد الإلكتروني email‏ 


! documentation والتوثيق‎ 


اعلى منصب للتوظيف في لينكس من قبل مدراء Aui‏ المعلومات [T‏ هو مسؤول أنظمة systems‏ 


.administrators 
الوضع الرسومي مقابل غیر الرسومي‎ ٢ 


نظام التشغیل لینکس Linux‏ يمكن استخدامه بأحد طريقتين؛ الأولى هي الواجهة الرسومية graphically‏ 
والثانية هي غير الرسومية non- graphically‏ تكون التطبیقات في الواجهة الرسومية على شكل نوافذ 
windows‏ قابلة للتحريك move‏ ولتغيير الحجم resize‏ القوائم menus‏ والأدوات tools‏ هي علامة فارقة 
في الواجهة الرسومية graphically mode‏ حيث آنها تساعدك في العثور على ما ترید البحث ade‏ كذلك 
ستجد متصفح ويب web browser‏ وأدوات تحرير الرسومات graphics editing tools‏ والبريد 


الإلكتروني email‏ الخاص بك. 


الشکل القادم هو مثال على جهاز سطح مكتب رسومي graphical desktop‏ لاحد أنظمة التشغيل في لينكس» 
ونری في يسار الشاشة شریط القوائم menu bar‏ وبه مجموعة من التطبيقات المشهورة popular‏ 
65 اما في الأسفل فنرى برنامج المستندات document‏ من باقة «LibreOffice‏ وكما نلاحظ 


يتم التعدیل بالمستند» أخيرا وفي الخلفیة نجد أحد مستعرضي الویب. 
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الواجهة الرسومية لعدد من التطبیقات في لینکس 
في الواجهة الرسومية mode‏ 11021م01/2؛ يمكن أن نقوم بفتح عدة واجهات بنفس الوقت؛ وهو أمر مفيد للغاية 
عند أداء المهام tasks‏ على أجهزة الحاسب البعيدة المتعددة multiple remote computers‏ حتی di‏ 
تستطيع ان تقوم بتسجيل الدخول log in‏ باستخدام اسم المستخدم username‏ وكلمة المرور الخاصة بك 


graphical interface خلال واجهة رسومية‎ ja password 


الشكل أدناه هو مثال على شاشة Juss‏ الدخول graphical login‏ في البيئة الرسومية graphical‏ 


interface 


„applications 


الواجهة غير الرسومية non-graphical mode‏ تقوم فيها بتسجيل الدخول القائم على النص text-based‏ 
0 کما هو موضح في الشكل آدناه. يُطلب منك اسم المستخدم الخاص بك username‏ وبعد ذلك كلمة 
المرور password‏ إذا تمت عملية تسجيل الدخول login‏ بشکل «successful gat‏ یتم نقلك مباشرة إلى 


- 
ےپ‎ 
نک‎ 1 ٧0 | A ji 
پروي هت ی‎ Jis. di 

Guest Session 

Rere Log 5 

ubuntu? 1304‏ 
شاشة تسجيل الدخول باستخدام اسم المستخدم وكلمة المرور 

بعد تسجيل الدخول dogging in‏ ستنتقل إلى مكتبي Cus desktop‏ يمكنك تحميل التطبيقات load‏ 
القشرة .Shell‏ 


اساسیات لینکس 


Ubuntu 13.04 ubuntu1 ttu? 


ubuntui1 login: 


واجهة تسجيل الدخول غير الرسومية في لینکس 


في الوضع الغير رسومي non-graphical mode‏ لا توجد نوافذ windows‏ للتحرك. على الرغم من وجود 
برامج تحرير النصوص text editors‏ ومتصفحات الويب web browsers‏ و عملاء البريد الإلكتروني 
email clients‏ الا أنهم جميعا عبارة عن نصوص فقط text‏ وكانت هذه هي الطريقة التي بدأ بها يونيكس 
“ا قبل وجود الواجهات الرسومية graphical environments‏ معظم الخوادم servers‏ تعمل في 
هذا الوضع أيضاء لأن المستخدمين لا يقومون بتسجل الدخول فيها بشكل مباشرء مما يجعل الواجهة الرسومية 
graphical interface‏ مضيعة للموارد resources waste‏ المثال التالي هو لما يمكن أن تراه بعد أن 


تقوم بعملية تسجيل الدخول logging in‏ 


oy 


اساسیات لینکس 


Ubuntu 13.04 ubuntu1 2 


The programs included with the Ubuntu system are free software; 
the exact distribution terms for each program are described in the 
individual files in /usr/share/doc/*/copuright. 


Ubuntu comes with ABSOLUTELY NO WARRANTY, to the extent permitted by 
applicable law. 


Helcome to Ubuntu 13.04 (GNU/Linux 3.8.0-19-generic x86. 64) 


x Documentation: https://help.ubuntu.com/ 


212 packages can be updated. 
91 updates are security updates. 


seanQubuntu1:^$ w 
20:08:35 up 14 min, 2 users, 1030 average: 0.45, 0.44, 0.32 

TTY FROM LOGING IDLE  JCPU PCPU WHAT 

ttu2 20:08 ۰ 14۶35 0.055 0.005 w 

tty7 :0 19:54 14:35 1:08 0.155 gnome-session = 
seanQubuntu1:"'$ .. 


مثال علی الشاشة بعد تسجیل الدخول 


في الشاشة السابقة نری موجة الدخول الأصلي original prompt to login‏ في الجزء العلوي من النص. 
أثناء عملية تسجيل الدخول dogin‏ ربما تشاهد بعض الرسائل «message‏ والتي تسمى رسالة ell‏ 
(MOTD)‏ وهي وسيلة مناسبة لمدير النظام systems administrator‏ للقيام بعملية تمریر المعلومات 
pass information‏ إلى المستخدمین 86۲5. بعد MOTD‏ ستجد موجه الأوامر .command prompt‏ 
نلاحظ في الشاشة أعلاه» أن المستخدم ادخل الأمر W‏ في موجهة الأوامر prompt‏ وهو یوضح حالات تسجیل 
الدخول على النظام. أيضا نری أنه تم ادخال الأوامر الجديدة ومعالجتها وتظهر على النافذة الطرفية «terminal‏ 
آما الأوامر الأقدم فتکون في أعلى الجلسة إلى أن تختفي. النافذة الطرفية terminal‏ هي المسوولة عن حفظ کل 
ما یظهر Jia «history kè‏ السماح للمستخدم بتحريك الموشر لأعلى scroll up‏ وروية الأوامر 


5 التي سبق ادخالها. بالنسبة للینکس ما یظهر في الشاشة هو الموجود بالنظام. 


۳ه 
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من الأوامر ككلمة واحدة إلى البرامج المعقدة complicated scripts‏ 13 قمت بتسجيل الدخول من خلال 
وضع النص text- mode‏ (الواجهة الغير الرسومية) فانت في وحدة التحكم console‏ اما إذا قمت بتسجيل 
الدخول في الواجهة الرسومية «graphical mode‏ فستحتاج للدخول إلى برنامج القشرة Shell‏ والتي هي 
وحدة تحكم نصبة text console‏ مع نافذة window‏ يمكن تحریکها move it around‏ أو تغيير حجمها 


resize 


كل جهاز مكتبي في لينكس Linux desktop‏ مختلف عن نظر انه» لذلك يجب أن تبحث في القوائم menus‏ 
الخاصة بك عن خيار نافذة طرفية terminal‏ أو .x-term‏ البرنامجين السابقين یمثلان القشرة ولكن بواجهة 
رسومية «shells graphical‏ والاختلاف بينهما في الغالب هو في الشكل appearance‏ لا في العمل 
function‏ إذا کان لديك أداة للبحث فيمكنك البحث عن كلمة terminal‏ كما هو موجود في نظام التشغيل 


Ubuntu أوبونتو‎ 


8 ٨ 
3 | © terminal 
lii. Applications 


E» 


خاصنية البحث 


هذه الأدوات exi tools‏ لك البحث search‏ بسرعة عما تريده في نظام التشغیل» بدلا من البحث من خلال 


۳٣‏ سطر الأوامر 
سطر الأوامر command line‏ هو إدخال نصي بسيط «simple text input‏ يتيح لك الادخال كما تريد» 
القوائم .menus‏ 


س0 اساسیات لینکس 
E‏ اھر y des‏ لکښ ساد 


لینکس هو نظام تشغیل متعدد المستخدمین «multiuser operating system‏ مما يعني أنه يمكن للعدید من 
المستخدمين users‏ العمل على النظام بشكل متزامن simultaneously‏ في الغالب؛ المستخدم العادي لا 
يمكنه الحاق الضرر بالمستخدمين الآخرين. ومع ذلكء هناك بعض القیود limitations‏ حيث أن بعض 
المستخدمین يقومون بالاستلاء على مساحة القرص disk‏ أو استخدام الكثير من الذاكرة memory‏ أو استهلاك 
موارد المعالج CPU resources‏ مما يجعل النظام بطيء للجميع. أيضا کل مستخدم في وضع تعدد المستخدمين 
multiuser mode‏ يمتلك فقط الصلاحيات الاساسية للمستخدم العادي «unprivileged users‏ مما يجعل 


تشغيل خادم الويب web server‏ الخاص US‏ مستخدم صعب جدا. 


الافتراضية تعمل لأن الخوادم servers‏ تكون معظم الوقت في وضع الخمول idling‏ وذلك لأنها لا تحتاج إلى 
موارد مادية physical resources‏ مثل الشاشة monitor‏ أو لوحة المفاتیح keyboard‏ لذلك وباستخدام 
تلك التقنية فأننا نستطيع أخذ معالج قوي powerful CPU‏ ونشره حول بين أجهزة ظاهرية متعددة multiple‏ 
virtual machines‏ مع الحفاظ على القسمة العادلة equitable sharing‏ بين الضيوف في نظام لينكس. 
ولكن وفي هذه الطريقة يوجد قيد limitation‏ وعادة هو الذاكرة memory‏ عدا ذلك ومع التقدم التكنولوجي 
لبرامج hypervisor‏ وللمعالجات CPUS‏ أيضاء أصبح من الممكن وضع آلات ظاهرية virtual machines‏ 


في البيئة الافتراضية» يوجد حاسب فعلي physical‏ واحد يسمى المضيف chost‏ يستطيع تشغيل العشرات من 
الأجهزة» حيث يقوم بتشغيل عدة نسخ من نظام التشغيل لعدد من الأجهزة ويسمون ضيوف .gUeSts‏ يقوم جهاز 
host‏ بتشغيل برنامج یسمی ۰۱۷۵06۳۷50۲ وظيفة ذلك البرنامج هي تبديل التحكم Switche control‏ بين 


مختلف الضيوف» مثلما يحدث في نواة لينكس عند العمل في العمليات الفردية. 


وبدعم من المعالج iudi‏ لن يعرف الضيوف آنهم على جهاز ظاهري. حيث يحصل كل ضيف على معالج 


افتراضي وذاكرة وصول عشوائي RAM‏ وقرص صلب HD‏ ويتواصلون في شبكتهم الخاصة. بل إنه ليس 


oo 
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من الضروري تشغیل نفس نظام التشغيل على جميع اجهزة الضیوف مما يقلل كذلك عدد من الخوادم المادیة 


.physical servers اللازمة‎ 


تقدم الافتراضية وسيلة لخفض استهلاك الطاقة lower power usage‏ وتقليل استهلاك مراكز البیانات على 
reduce datacenter space‏ الخوادم الفعلية physical servers‏ الضيوف هم الآن مجرد برامج معدة 
a3 «software configurations‏ فمن Ded!‏ اختبارها testing‏ وانهائها destroy‏ عندما تنتهي الفائدة 
منها. 

من الممكن تشغیل نظام تشغيل لحظي متعدد multiple instance‏ على جهاز فعلي physical machine‏ 
واحد وتوصیله connect‏ عبر الشبكة «network‏ عندها يكون موقع location‏ الجهاز غير ذات أهمية. 
الحوسبة السحابية Cloud computing‏ تأخذ هذا النهج» وتتيح لك الحصول على جهاز ظاهري virtual‏ 
6 في مراكز البیانات البعيد remote datacenter‏ التي لا تملکھاء وتدفع فقط للموارد resources‏ 


التي تستخدمها. 


مزودي vendors‏ خدمة الحوسبة السحابية Cloud computing‏ يمكنهم الاستفادة اقتصادیا economy‏ 


بتقدیم مواردهم computing resources‏ بأسعار أفضل من تكلفة cost‏ شراء تلك الأجهزة کأجهزة الفضاء. 


الخوادم الظاهرية virtual servers‏ هي الوجه الاخر للحوسبة السحابية. حيث يمكنك الحصول على تخزین 
الملفات file storage‏ وعلى ae! ji‏ البیانات «databases‏ أو حتی على مجموعة من البرمجیات „Software‏ 
المفتاح في معظم هذه المنتجات products‏ هو أن تدفع مقابل ما تستخدم» مثل كمية معينة لکل جیجابایت من 


البیانات شهریاء بدلا من شراء الأجهزة والبرمجیات. 


بعض الحالات some situations‏ أكثر ملاءمة للسحابة cloud‏ من غیرها. المخاوف الأمنية security‏ 
performance els‏ عادة ما تكون العناصر الأولى في عملية الاختیار. ثم تلیها التكاليف costs‏ وفعالية 


functionality الوظائف‎ 


كه 
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يلعب لينكس دورا محوريا pivotal role‏ في ås sall‏ السحابية cloud computing‏ تعمل معظم الخوادم 
الظاهرية virtual servers‏ على as‏ انوية لينكس Linux Kernel‏ وغالبا ما تستخدم لينكس لاستضافة host‏ 


التطبيقات applications‏ وراء خدمات الحوسبة السحابية .cloud computing services‏ 
٥‏ استخدام لينكس للعمل: 


الأدوات الأساسية basic tools‏ المستخدمة في معظم المكاتب Offices‏ هي: 


Word processor oa saill ه معالج‎ 
Spreadsheet الجداول الإلكترونية‎ e 
Presentation package ه حزمة العرض‎ 


Web browser متصفح الويب‎ o 


برنامج OpenOffice‏ وبرنامج LibreOffice‏ یهتمان بالخدمات السابقة. حيث بستخدم معالج النصوص 
word ۲‏ لتحرير الوثاتق» مثل التقاریر والمذکرات. آما الجداول الالکترونية Spreadsheets‏ 
فهي مفيدة للعمل مع الأرقام کتلخیص المبیعات و عمل توقعات مستقبلية. LÍ‏ حزمة العرض presentation‏ 
فتستخدم لانشاء الشرانح slides‏ مع إضافة بعض من المکونات Jia‏ النصوص text‏ و الرسومات graphics‏ 
والفيديو هات المدمجة embedded video‏ الشرائح قد تکون مطبوعة printed‏ أو معروضة displayed‏ 


على شاشة screen‏ أو على جهاز الاسقاط projector‏ لمشارکتها مع الجمهور. 


مبين أدناه برنامجي الجداول الالکترونية spreadsheet‏ ومحرر نصوص document editor‏ التابعین 
لمجموعة .LibreOffice‏ لاحظ أن spreadsheet‏ لیس مقید بعدد محدد من الصفوف ۲۵۷/5 والأعمدة 
۵5 كما یمکن للارقام أن تکرن مصدرا source‏ للرسم البياني graph‏ ۰ ونری أن الصیغ formulas‏ 
یمکن کتابتها لحساب القیم calculate values‏ على ضوء المعلومات information‏ المعطاة مثل حساب 


نسبة الفائدة ومبالغ القروض معا وذلك للمساعدة في مقارنة جمیع الخیارات. 


oy 
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باستخدام محرر LibreOffice‏ يمكن أن يحتوي المستند document‏ على نص text‏ ورسومات graphics‏ 
وجداول البیانات data tables‏ وأكثر من ذلك. كما ويمكنك ربط المستندات documents‏ وجداول البیانات 
5 معاء. على سبیل المثال يمكنك القيام بعملية تلخیص summarize‏ البیانات في شکل مکتوب 
«written form‏ وبشکل تلقائي فأن أي تغییرات تتم على ذلك جدول spreadsheet‏ ستظهر في المسند 


document‏ المر تبط به. 


fy «‏ د 


memo1.odt - LibreOffice writer 
R- یکاټ ناك 5 اما څ 28 فا‎ 
E [ext Bodv 


Lorem ipsum dolor sit amet, consectetur adipiscing elit. ۸ 
leo, vel dictum ipsum. Quisque quam est, facilisis eget m. 
mattis aliquet massa vitae blandit. Cum sociis natoque pe 
nascetur ridiculus mus. Nunc vitae quam vehicula, ultrici 
egestas elementum, 


کا Curabitur quis diam porttitor, pretium dui‏ مم 
lerisque. Nulla facilisi. Cum sociis natoc-‏ 


etur ridiculus mus. Maecenas scelerísqi 

leo dignissim occi adipiscing varit‏ اس لوب تح 
torquent per conubia nostra, per inceptos hi‏ 

et tempus tellus tempor. In diam quam, condimentum vitz 


accumsan eu mauris volutpat elementum. Duis lobortis P 
mollis. 


p سس‎ | 
Phasellus posuere libero vel ligula mo: egestas. Donc 


i Ut viverra pulvinar volutpat, Cras blandit tristique ipsum; 
20020401 — 20120701 100. Curabitur eget bibendum mi. Nullam porta metus vitae ri: 
pulvinar dui dui, in ultrices lacus porttitor nec. | 


١ 
Nunc nec dolor et tortor ultrices ultricies. Donec ۸ 
viverra ipsum molestie sem sodales venenatis. Phasellus «z 

DAY ہے‎ lit. Pha«ellus lobortis erat a nunc fermennim rhoncus. Ne 
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مثالين من برامج حزمة LibreOffice‏ 


LibreOffice‏ یمکن أن یقوم Lad‏ بعمل تنسيقات formats‏ للملفات الأخریء مثل Microsoft Office‏ أو 
ملفات تنسيق المستندات المحمولة Adobe Portable Document Format (PDF)‏ , بالإضافة إلى ذلك 


وباستخدام ملحقات extensions‏ يمكن دمجھ مع برامج ويكي Wiki software‏ لإعطائك انترانت قوي 


.powerful intranet 
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ینظر المتصفحان فایرفوکس Firefox‏ وجوجل کروم Google Chrome‏ لنظام التشغيل لينكس على انه 
العميل المهم لديهم. لذلك يمكنك أن تتوقع أن يكون لديك أحدث البرامج latest software‏ المتاحة في نظامك 
للمتصفحين السابقين. والحصول على المميزات الجديدة new features‏ وإصلاح الأخطاء bug fixes‏ بأسرع 
وقت. بعض الاضافات Jis plugins‏ أدوبي فلاش Adobe Flash‏ قد لا تعمل دائما بشكل صحيح لأنهم 


يهتمون بشركة أخرى غير „Linux‏ 


لينكس لا يهتم إذا كنت على لوحة المفاتیح keyboard‏ لجهاز حاسب computer‏ أو متصل عبر الانترنت» 


لذلك عليك أن تأخذ في الحسبان بعض الاحتياطات الأساسية للتأكد من ان بياناتك data‏ آمنة ومحصنة. 


أسهل ما يمكنك القيام به هو استخدام كلمة مرور password‏ فريدة unique‏ وجيدة good‏ في كل موقع 
ومكان نستعرضه» وخصوصا على جهازك المحلي local machine‏ كلمة السر الجيدة لا تقل عن ٠١‏ حروف 
وتحتوي على مزيج من الأرقام والحروف والرموز الخاصة. استخدم حزمة مثل KeePassX‏ لتوليد كلمات 
السرء وبعد ذلك كل ما يجب عليك فعله هو تسجيل الدخول بكلمة المرور login password‏ إلى جهازك ثم 


كتابة كلمة المرور لفتح ملف KeePassX‏ الخاص بك. 


قم بعمل نقطة جدولة دورية للتحقق من وجود تحديثات updates‏ الشاشة التالية مثال على ضبط تحديث 


برامج أوبونتو Ubuntu software update configuration‏ والذي يتوفر من قائمة الإعدادات. 


Automatically check for updates: | Daily 


when there are security updates: | Display immediately 


when there are other updates: | Display weekly 


Notify me of a new Ubuntu version: | For any new version 


Software Updater 


٠١ Updated software is available for this 
[^] computer. Do you want to install it now? 


> Details of updates 
2 79.1MBwill be downloaded. 


[ Settings... ] [ Remind Me Later ] l Install Now ۱ 


ضبط تحدیث برامج أوبونتو 


في الجزء العلوي من الشاشة السابقة» نری خاصية التحقق من وجود تحدیثات بشکل يومي .daily basis‏ إذا 
كانت هناك تحدیثات تتعلق بالأمان «security updates‏ سیتم على الفور سوالك للقیام بتثبيتها. خلاف ذلك» 
سوف تحصل على التحدیثات على شکل دفعات أسبوعية batched up‏ اما الجزء السفلي من الشاشة فهو نافذة 
حوار تظهر عند وجود Hinai‏ جديدة updates‏ کل ما عليك فعله هو الضغط على التثبیت Install y!‏ 


NOW‏ وسیتم التحدیث! 


وأخیراء سوف تحتاج إلى حماية جهاز الحاسب الخاص بك من قبول الاتصالات الواردة incoming‏ 
5 جدار الحماية firewall‏ هو جهاز تصفية filter‏ حركة مرور الشبكة «network traffic‏ 
ولینکس لدیها واحد مدمج في نظامها. gufw‏ هو واجهة رسومية graphical interface‏ لجدار الحماية والغیر 


معقد لنظام التشغیل أوبونتو Ubuntu‏ 


سا سب اسا 
x‏ ۴ 
$ 
Me‏ ۱ 
ES‏ اساسیات لینکس 2:50 
مت 1 
=Œ 1 4) 2:54PM it‏ ی Software Updater‏ 
Ubuntu Software Other Software | Updates | Authentication | Additional Drivers‏ : 
Install updates from:‏ 
Important security updates (raring-security) |‏ 
y Recommended updates (raring-updates)‏ 3 
Pre-released updates (raring-proposed)‏ ( 
Unsupported updates (raring-backports)‏ 
3 
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Q/tmp/dbus-12CE5p 
/[run/user/sean/ke 


/tmp/ . 11-0۸ 908 
/run/user/sean/ke 


/[var/run/acpid.so 


/[run/udev/control 
/run/user/sean/ke 
/run/user/sean/ke 

| 
/tmp/pulse-2L9K88 


/[run/user/sean/pu 


| 
/[var/run/dbus/sys 


Q/dbus-vfs-daemon 


| 


/var/run/avahi-da 


ENING 10636 1649/dbus -daemon 


10874 


ENING 
ENING 8458 
ENING 11396 


unix 2 [ ACC ] 
yring-O0pS3ui/control 
unix 2 [ ACC ] 
eMlGn7/native 

unix 2 [ ACC ] 
lse/native 

unix 2 [ ACC Î 
tem bus socket 

unix 2 [ ACC ] 
/[socket-Vp49tvOx 

unix 2 [ ACC ] 
emon/socket 
seanQubuntu1:-S$ netstat 
(Not all processes coul 
will not be shown, you 
tcp 0 ہ‎ 177 Listening Report 


Incoming: | Deny v | 


Outgoing: | Allow ۳ | 


Rules 


| To Action 


+ - 


tcp 0 07 


Protocol Port 
seanQubuntu1:-$ 


Address | Application 
dhclient 


avahi-daemon 


|UDP 42652 * 
|UDP 43648 * 


|UDP A353: 3 avahi-daemon 


Donate £X 


جدار حمایة أوبونتو 


ببساطةء عند تغيير حالة الإعدادات إلى فعال 01ء سوف تقوم بحجب block‏ کل حركة المرور traffic‏ والقادمة 


إلى جهاز الحاسب computer‏ الخاص بك الا إذا قمت بإنشاتها initiated‏ بنفسك. يمكنك اختیار selective‏ 


الاتصالات التي تريدها والسماح allow‏ لها بالمرور من وإلى جهازك وذلك عن طریق النقر على علامة زائد 


.plus sign 


الجدیر بالذکرء انت تستخدم برنامج iptables‏ والمدمج built-in‏ في نظام system‏ جدار الحماية 


firewall‏ وهو متوفر في واجهة المستخدم الرسومية Graphical User Interface -(GUI)‏ فبدلاً من 


كتابة اكواد البرنامج المعقدة؛ یتم استخدم الواجهة الرسومية. تلك الواجهة تسمح لك ببناء نظام فعال effective‏ 


policy‏ لجھاز لينكس المكتبي desktop‏ ولكنه لا يقارن بما يستطيع iptables‏ أن يقوم به. 


ل 
Firewall Configuration‏ 
unix 2 [ ACC STREAM‏ 
E 48FS‏ 
unix 2 [ ACC STREAM‏ 
yring-0pS3u1/gpg‏ 
EN unix 2 [ ACC STREAM‏ 
unix 2 [ ACC STREAM‏ 7 
yring-O0pS3u1/ssh‏ 
unix 2‏ 
1 
cket Firewall‏ 
i Firewall‏ د unix‏ 
unix‏ 
ON‏ 
yring-0pS3u1/pkcsi1 SIEUT‏ 
١‏ | 
m|‏ 
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عندما تتصفح الویب eweb‏ فانك تترك بصمة رقمية digital footprint‏ خاصة بك. الكثير من معلومات 
67 هذه البصمة یتم تجاهلها ۰1000۲60 وبعضها يتم تجمیعه لخدمة الإحصاءات collect‏ 
56 والمستخدمة للدعاية «advertising‏ ولكن بعض تلك المعلومات يمكن استخدامها لأغراض خبيثة 


.malicious purposes 


Y هذا الموقع» فان كلمة السر المخترقة‎ hacked مختلفة في کل موقع بحیث اذا تم اختراق‎ passwords 
هو أسهل طريقة‎ KeePassX إلى حساباتك في مواقع أخرى. قم باستخدام‎ access يمكن استخدامها لدخول‎ 
التي تعطیها إلى المواقع‎ information كمية المعلومات‎ limit لتوليد كلمات مرور وحفظها. وأیضا قم بتقليل‎ 
إلى ما هو مطلوب فقط. فمثلا اعطاء اسم والدتك وتاریخ الميلاد قد يساعد في استعادة حسابك في الشبكة الاجتماعية‎ 
إذا فقدت كلمة المرور الخاصة بكہ ولكنه في نفس الوقت قد يستخدم ضدك بغرض انتحال‎ social network 


شخصيتك impersonate‏ والوصول إلى حسابك البنكي. 


المحفوظات أو الكوكيز Cookies‏ هي الطريقة الرئيسية main mechanism‏ التي تستخدمها المواقع 
56 لتعقبك track‏ في بعض الأحيان يكون التتبع جيد مثل تتبع عربة التسوق الخاصة بك أو في عملية 


التسجيل مرة اخرى عند العودة إلى نفس الموقع. 


عندما تتصفح مواقع الانترنت» يقوم خادم الويب بإرسال ملفات Cookies‏ (وهي عباره عن جزء صغیر من 
النص) مع صفحة الويب التي طلبتها. متصفحك يقوم بتخزين تلك الملفات ثم يقوم بإعادة ارسالھا عند كل طلب 
جديد منك لذلك الموقع. لذلك فان لكل موقع من مواقع الانترنت ملف Cookies‏ خاص به فمثلا لا يتم إرسال 


المحفوظات من موقع example.com‏ إلى موقع .example.org‏ 


العديد من المواقع لديها نص مدمج embedded scripts‏ يأتي من طرف ثالث «third parties‏ مثل لوحة 
إعلانيه banner advertisement‏ أو تحليلات تتبعيه analytics pixel‏ تتبع البیکسل tracking pixel‏ 
هو تتبع وصول المستخدم إلى محتوى ما على شبكة الانترنت. فإذا کان موقع example.com‏ وموقع 


“y 
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۲۵9 بحتویان على بکسل تتبع tracking pixel‏ مثلا من المعلن» فانه سیتم ارسال ملف 
المحفوظات Cookies‏ نفسه عند تصفح كلا الموقعين. عندها سيعلم المعلن أنك قمت بزيارة example.com‏ 


.example.org و‎ 


عند الضغط على زر الإعجاب "Like"‏ في alte‏ الشبكات الاجتماعية «social network‏ ومع الوصول الكافي 
للمعلومات broad enough reach‏ فأنه يمكن أن يحصل موقع website‏ على شبكة الانترنت على معرفة 
الصفحات التي تقوم عادة بتكرار زيارتها؛ وبالتالي معرفة اهتماماتك الشخصية interests‏ وشريحتك السكانية 


.demographics 


هناك استراتيجيات strategies‏ مختلفة للتعامل مع هذا الأمر. منها مثلا أن تقوم بتجاهل ignore‏ موضوع 
التتبع. اما الأخری فهي limit as!‏ من نتبع البیکسل tracking pixels‏ الذي تقوم ed sis‏ إما عن طريق منع 
التتبع تماما blocking‏ أو عن طريق القیام بعملیة حذف بيانات التتبع clearing them out‏ بشكل دوري 


.periodically 


في الشكل أدناه نرى الاعدادات settings‏ المتعلقة بالمحفوظات cookie‏ في متصفح الفایرفوکس .Firefox‏ 
في الجزء العلوي نشاهد أن المستخدم user‏ اختار لا لعملية التتبع no to track‏ وهي في الحقيقة عبارة عن 
علامة اختيارية voluntary tag‏ تصاحب أي طلب request‏ ترسله لأي موقع. هناك بعض المواقع ستحترم 
رخبنك. آما في الجزء السفلي فنری اختیار لا لتذکر never remember‏ المحفوظات cookie‏ من طرف 
ثالث «third party cookies‏ كما نری آیضا الاختیار حذف remove‏ المحفوظات العادية regular‏ 


Jis cookies‏ تصفح موقع ما وذلك بعد اغلاق البرنامج. 


التغییر في اعدادات الخصوصية privacy settings‏ یجعلك مجهول anonymous‏ على الانترنت 
1 ولکن یمکنه أيضا أن يسبب مشاکل مع بعض المواقع sites‏ التي تعتمد على ملفات المحفوظات من 
طرف ثالث third party cookies‏ إذا حدث ھذاء فسیکون لديك المقدرة للسماح لبعض ملفات المحفوظات 


ليتم حفظیا. 


TY 


x 
Me 
ین اساسیات لینکس‎ 
ا سرا‎ 
Tm 2 با‎ EN 
ھت لا‎ ê Š ao G 
General Tabs Content Applications Security Sync Advanced 
Tracking 
© Tell sites that I do pot want to be tracked. 
O Tell sites that I want to be tracked, 
O Do not tell sites anything about my tracking preferences. 
Learn More 
History 
Firefox will: Use custom settings for history 2 | 
۲ Always use private browsing 6 
& Remember my browsing and download history 
S Remember search and form history 
کا‎ Accept cookies from sites Exceptions... 
Accept third-party cookies; | Never A 
Keep until: | close Firefox = | Show Cookies... | 
O) Clear history when Firefox closes Settings... 
Location Bar 
When using the location bar, suggest: History and Bookmarks 2 | 
Help . Close 
Firefox خیارات المحفوظات في متصفح‎ 
على الاطلاق.‎ not track أو عدم التتبع‎ search history تاریخ بحث‎ forget هنا أيضا لديك خیار لنسیان‎ 
على جهاز‎ record Js لن يكون هناك‎ esearch history removed مع إزالة عملیات البحث السابقة‎ 
التي قمت بزيارتها.‎ sites الحاسب المحلي الخاص بك من المواقع‎ 
download على شبكة الانترنت» فيمكنك تحمیل‎ anonymous إذا كنت تشعر بقلق بالغ بان تكون مجهول‎ 
والذي هو‎ Onion Router المتصفح السابق هوا اختصار لما يسمى‎ Tor Browser واستخدام متصفح‎ 
تعمل على اخفاء حركة المرور‎ servers تدير خوادم‎ network of publically عبارة عن شبكة عامة‎ 
وبعبارة‎ «stripped down version الخاصة بك. المتصفح الذي يأتي مع تلك الحزمة لا يحتوي على مزايا‎ 
لذلك السبب قد لا تعمل بعض المواقع‎ scripts لا يقوم بتنفيذ أي برنامج نصي‎ Tor Browser أخرىء فان‎ 
الخاصة بك إذا‎ identity بشكل صحيح. ومع ذلك. فان هذا المتصفح هو أفضل وسيلة لاخفاء الهوية‎ sites 
5 
لله‎ 


آساضرات لیکن 2030 


المعمل الرابع - أساسيات سطر الأوامر 


Command Line Skills 


AW‏ اساسیات لینکس 
f,‏ مقدمة 


هذا هو المعمل الرابع: أساسيات سطر الأوامر. عن طريق آداء هذا المعمل سوف تتعلم كيفية استخدام القشرة 


.shell 
في هذا التمرینء سوف تقوم بالمهام التالية:‎ 


و استکشاف ممیزات „Bash‏ 
o‏ اتخدام المتغيرات في shell‏ 
e‏ فھم كيفية استخدام .globbing‏ 


e‏ القدرة على الاستفادة من الاقتباس. 
٢‏ الملفات والمراجع 


في هذه المھمة فاننا سوف نعمل على واجهة سطر الأوامر Command Line Interface — (CLI)‏ في 
نظام التشغیل لینکس وذلك لتعلم و استکشاف كيفية كتابة الأوامر الأساسية ومن ثم تنفیذها. 

معظم المستخدمین على دراية بكيفية تنفيذ الأوامر باستخدام واجهة المستخدم الرسومية Graphical User‏ 
Interface — (GUI)‏ لذلك فان هذه المهمة ستقدم بعض المفاهیم الجديدة إذا كانت هذه هي المرة الأولى التي 
تتعامل فیها مع LOL]‏ لاستخدام CLI‏ فسوف تحتاج إلى كتابة الأمر الذي تريد تشغیله UD‏ 

في نظام النوافذ window‏ سوف تکتب الأمر کتطبیق محاكي terminal emulator application‏ داخل 
النافذة الطرفية Terminal‏ وسیعرض النظام system‏ موجه سطر الأوامر «prompt.‏ والذي يتبعه مؤشر 
وامضء كما هو واضح في الشکل ادناه: 


موجه الأوامر prompt‏ 


قد تحتاج إلى الضغط على مفتاح Enter Jay‏ وذلك لعرض موجه الأوامر. 
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س0 اساسیات لینکس 


موجه الأوامر prompt‏ يزودك aub‏ المستخدم الحالي للنظامء وهو في الحالة السابقة sysadmin‏ كما يخبرك 
آیضا باسم المضيف أو جهاز الحاسب الذي تستخدمه وهو هنا localhost‏ وأخيرا الدلیل المحلي directory‏ 
ويرمز له بعلامة تيلدا ~. 

عند كتابة آمر فسوف یظهر ذلك الأمر في مؤشر النص text cursor‏ لتحریر ما تقوم بكتابته من الأوامر 
يمكنك استخدام مفاتيح التحکم مثل البداية home‏ ونهاية end‏ ومسافة للخلف backspace‏ ومفاتيح الأسهم 
arrow keys‏ بغرض التحریر. 


وبمجرد الانتهاء من كتابة الأمر بشکل صحیح؛ اضغط Enter‏ لتنفیذ ذلك. 
۶,۲۱ الخطوة ۱ 


الأمر التالي یعرض نفس المعلومات التي تراها في الجزء الأول من الموجه prompt‏ و هو اسم المستخدم الحالي 


للنظام. تأکد من أنك قمت بالنقر على نافذة Terminal‏ أولا ثم اکتب الأمر التالي يليه مفتاح :Enter‏ 


whoami 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ whoami 


sysadmin 


تنفیذ الأمر whoami‏ 
نتيجة تنفیذ الأمر whoami‏ في المثال السابق هو sysadmin‏ وهو يعرض اسم المستخدم الحالي. على الرغم 
من أن اسم المستخدم الخاص بك معروض في الموجه ولكن وفي حالة عدم وجوده فیمکن أن تستخدم الأمر السابق 


للحصول على تلك المعلومة. 


TN 


اساسیات لینکس 


39 الخطوة ۲ 


يعرض الأمر التالي معلومات حول النظام الحالي. لتتمکن من روية اسم النواة kernel‏ الذي تستخدمهاء اكتب 


الأمر التالي في terminal‏ 


uname 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


تنفیذ الأمر uname‏ 


العدید من الأوامر التي يتم تنفيذها تخرج على بشکل نصي. يمكنك تغییر التنفيذ التي تنتجه الأوامر باستخدام 
خیارات options‏ بعد الأمر. 

الخيارات لأمر ما يمكن ان تحدد بعدة طرق. تقليديا في يونيكس (UNIX‏ تكتب الخيارات بواسطة شرطة يليها 
حرف آخر مثل D‏ 

اما في لينكس Linux‏ الخيارات في بعض الأحيان يمكن أن تكتب بواسطة شرطتان تليها كلمة واحدة أو كلمة 
.-Énodename Ji ål pa ga‏ 

نفذ الأمر uname‏ مرة أخرى في «terminal‏ مرة مع الخیار 0- ومرة أخرى مع الخيار .--nodename‏ 


وذلك لعرض اسم مضيف الشبكة (کما هو موجود في الموجه (prompt‏ 
uname -n‏ 


uname --nodename 


وينبغي أن يكون التنفیذ مشابه لما يلي: 


1۸ 


اساسیات لینکس 


:~$ uname -n 


localhost 


is $ uname --nodename 


localhost 


uname --nodename (uname -n تنفيذ الأمرين‎ 


۳٢ £v‏ و 


يستخدم الأمر pwd‏ لعرض الموقع الحالي أو الدليل الحالي directory‏ اكتب الأمر التالي لعرض دليل العمل 


:directory 


pwd 


وينبغي آن یکون التنفیذ مشابه لما يلي: 


/home/sysadmin 


تنفیذ الأمر pwd‏ 
الدلیل directory‏ الحالي في المثال Aei‏ هو .home/sysadmin‏ ويشار اليه أيضا بانه di»‏ 


البداية your home directory‏ ۰ وهو مكان خاص للمستخدم» حيث يستطيع التحكم بالملفات files‏ الموجودة 


بنفس اسم المستخدم ويقع تحت دلیل Jhome‏ 

يستخدم لینکس الخط المائل (/) لفصل الدلائل directories‏ لعمل ما يسمى بالمسارء وهو AUS‏ في نتيجة تنفيذ 
الأمر السابق /home/sysadmin‏ . الخط المائل الأول يمثل دليل المستوى الأعلى top level directory‏ 
والمعروف باسم الدليل الجذر „root directory‏ 

الحرف lali‏ )~( الظاهر في الموجه prompt‏ يشير أيضا إلى الدليل الحالي. هذا الحرف هو اختصار لتمثيل 


.home ll دليل‎ 


1۹ 


اساسیات لینکس 


لمعلوماتك: pwd‏ اختصار لطباعة دليل العمل print working directory‏ حيث أن آلات يونيكس القديمة 
لم يكن فيها شاشات «monitors‏ وإخراج الأوامر كان بالطباعة ومن هنا جاء هذا الاسم. الجدير بالذكر انه 


لا تحدث طباعة فعلية في الإصدارات الحديثة ولكن الأمر بقي كما هو. 


٣‏ متغيرات القشرة 


تستخدم متغيرات القشرة Shell variables‏ لتخزين البيانات في لينكس. وتستخدم هذه البيانات عن طريق 
القشرة نفسها وكذلك البرامج والمستخدمين. 


يركز هذا القسم على معرفة كيفية عرض قيم المتغيرات القشرة. 


۱ الخطوة ۱ 


يمكن استخدام الأمر echo‏ لطباعة النص text‏ وقيمة المتغیر value of a variable‏ ولاظهار التطابقات 
65 في بيئة القشرة (سيتم الحديث عنه لاحقا في هذا المعمل) . اکتب الأمر التالي للحصول 


على النص المدخل كما يلي: 


echo Hello Student 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo Hello Student 


Hello Student 


echo Hello Student تنفیذ الأمر‎ 


Y الخطوة‎ ۳۲ 


اکتب الأمر التالي لعرض Xa‏ المتغیر :PATH‏ 


اساسیات لینکس 


echo $PATH 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo $PATH 


/home/sysadmin/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/s 


bin:/bin:/usr/games 


$ 


echo $PATH تنفیذ الأمر‎ 


يتم عرض المتغير عن طريق وضع علامة الدولار $ أمام اسم المتغير. 

يستخدم هذا المتغير للعثور على اماكن تخزين الأوامر. کل المراجع directories‏ المذكورة أعلاه يتم البحث 
فيها عند làn‏ الأمر. على سبيل المثال إذا حاولت تشغيل الأمر date‏ فستظهر القشرة في البداية كما يلي 
./home/sysadmin/bin directory‏ ثم في /usr/local/sbin directory‏ . وحالما يتم العثور على 
الأمر فان القشرة ستقوم بتشغيله Un‏ 


Y الخطوة‎ ۳ 


یستخدم الأمر which‏ لتحديد ما إذا کان هناك ملف اسمه تاریخ date‏ قابل للتنفيذ وموجود في الدليل 


:PATH والمدرج في قيمة‎ directory 


which date 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


525 which date 


/bin/date 


which date Y! تنفیذ‎ 


۷۱ 


A‏ اساسیات لینکس 


نتيجة الأمر which‏ تخبرك أنه عند تنفیذ الأمر date‏ فان النظام سيشغل الأمر /bin/date‏ وکما ذکرنا يستخدم 


الأمر which‏ لتحديد موقع الأمر 0816. 
Globbing ٤‏ 


آحرف glob‏ في لينكس Linux‏ مشابهه لما یعرف في العديد من أنظمة التشغیل باسم "wildcard"‏ فباستخدام 


آحرف glob‏ تستطيع العثور على أسماء الملفات بواسطة نمط من الأنماط. 


أحرف glob‏ هي من مميزات القشرة وليست مرتبطة بأمر معين. وتبعا لذلك يمكنك استخدام أحرف glob‏ مع 


أي أمر من أوامر لینکس „Linux command‏ 


عندما يتم استخدام أحرف glob‏ تقوم القشرة shell‏ بتوسيع كامل النمط لمطابقة match‏ کل الملفات fles‏ 


في الدلیل directory‏ المحدد والتي تطابق نمط أحرف .glob‏ 
للتوضيح سوف نستخدم الأمر echo‏ لعرض عملية التوسع. 
١‏ الخطوة ١‏ 
استخدم الأمر echo‏ لعرض كافة أسماء الملفات في الدليل الحالي والتي تطابق النمط " * ": 
echo *‏ 
وينبغي أن يكون التنفيذ مشابه لما يلي: 


:-$ echo * 


Desktop Documents Downloads Music Pictures Public Templates Videos 


و : 


تنفیذ الأمر * echo‏ 


۷۲ 
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النجمة asterisk‏ * " تطابق صفر أو أكثر من الأحرف في اسم الملف. في المثال أعلاه فان الناتج مطابق 


لجمیع أسماء الملفات filenames‏ في الدلیل الحالي .directory‏ 


اما الأمر echo‏ فهو الذي يقوم بإخراج أسماء الملفات على الشاشة. 


Y الخطوة‎ ٤٤٦٣٢ 


الأوامر التالیة ستعرض كافة الملفات في الدليل الحالي التي تبدأ بحرفي 0 و : 


echo D* 


echo P* 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


echo 7‏ وه 


Desktop Documents Downloads 


: وه‎ echo P* 


Pictures Public 


echo P* «echo D* تنفيذ الأمرين‎ 


في المثال * D‏ تم عرض جميع أسماء الملفات في الدليل الحالي التي تبداً بحرف D‏ 


Y الخطوة‎ ٤ر‎ ٤٣ 


علامة النجمة asterisk‏ " * " يمكن استخدامها مقابل أي حرف من حروف الكلمة أو الاسم. مثلاً الأمر التالي 


یعرض کافة الملفات files‏ في الدلیل directory.‏ الحالي التي تنتهي بحرف 5: 


echo *s 


۷۳ 


اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


5 29 ٣ 


Documents Downloads Pictures Templates Videos 


وه : 


echo *s تنفیذ الأمر‎ 


٤ الخطوة‎ ٤٤٤ 


لاحظ أن أيضا ان النجمة asterisk‏ أن تکتب عدة مرات في كلمة أو في عدة کلمات ايضا: 


echo 5 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


5265 echo D*n*s 


Documents Downloads 


echo D*n*s تنفيذ الأمر‎ 


سوف ندرس في احرف glob‏ علامة الاستفهام question mark‏ "* ". علامة الاستفهام تطابق تماما حرف 


as واحد‎ 


علامة الاستفهام يمكن استخدامها مثل النجمة في أي مكان في الكلمة ويمكن أن تكتب ایضا عدة مرات. 


o الخطوة‎ ٤ر‎ ٤ر٥‎ 


بما أن كل علامة استفهام تطابق حرف واحدة اذن فان كتابة ستة علامات استفهام سوف تطابق ستة احرف. اكتب 


مايلي لعرض أسماء الملفات المكونة من ستة أحرف: 


ME 


: 
Ww 
اساسيات لینکس‎ AN 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Public Videos 


هام: كل علامة استفهام ؟ يجب أن تتطابق مع حرف واحد فقط في اسم الملف» لا أكثر ولا اقل. 


٩ الخطوة‎ £,£,1 


تستطیع استخدام علامة الاستفهام مع أحرف glob‏ الأخرى في Adae‏ المطابقة. اکتب ما يلي لعرض آسماء 


الملفات التي تبدأ بحرف D‏ وتتکون من تسعة أحرف: 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


Documents Downloads 


V الخطوة‎ ٧ 


يمكن الجمع بين حروف glob‏ في نفس الأمر. يعرض الأمر التالي أسماء الملفات التي لا يقل عن Aia‏ أحرف 


اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


لمطابقة علامة النجمة» وأخيرا الأسماء التي تنتهي بحرف 5. 


۸ الخطوة‎ ٨ 


الحرف التالي من glob‏ مشابه لحرف علامة الاستفهام والتي تطابق حرف واحد. 


تستخدم الأقواس المربعة square brackets‏ "][ " لتحديد التطابق» حيث ان الحرف یمکن أن يكون قائمة list‏ 


أو مدى range‏ محدد والذي یعرف باسم à‏ الحرف .character class‏ 
ویمکن أيضا اختبار النفي مع علامة التعجب "exclamation point‏ ! " كحرف للاستثناء. 


فنجد في المثال echo [DP]*‏ ان الحرف الأول من اسم الملف یمکن أن یکون اما D‏ أو ۴. بينما في مثال 


echo [DP]* 


echo [!DP]* 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


YA 


اساسیات لینکس 


:~$ echo [DP]* 
Desktop Documents Downloads Pictures Public 


:~$ echo [!DP]* 


Music Templates Videos 


D$ 


echo [!DP]* «echo [DP]* o! تنفیذ‎ 


4 الخطوة‎ ٤٤۹ 


في الأمثلة القادمقه سيتم تحديد مدی range.‏ معين من الأحرف. في المثال echo [D-P]*‏ الحرف الأول من 
اسم الملف يمكن أن يكون أي حرف ابتداء من D‏ ونهاية ب P‏ اما المثال echo [ID-P]*‏ فهو یخرج عكس 
المثال الأول حيث يظهر الملفات التي لا تکون واقعة في المدی المحدد اعلاه: 

echo [D-P]* 


echo [!D-P]* 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo [D-P]* 
Desktop Documents Downloads Music Pictures Public 


×9 +۷١۷٣ 


Templates Videos 


تنفيذ الأمرين echo [ID-P]* «echo [D-P]*‏ 
إذن الملفات التي ظهرت بدايتها أحد الحروف التالية تبعا للمدى المحدد وهي ٣ (E)‏ ؛ H‏ |ء ل؛ ۸ء Lء M‏ 
و (O‏ ولكن ماذا لو کان المدی من رقم ۱ إلى حرف A‏ [۸۔۱]؟ 
الجواب هو استخدام جدول نص للغة اسكي كود ASCII‏ والتي تحدد المدی من وإلى. يمكنك عرض هذا الجدول 


عن طريق البحث عنه على الانترنت أو كتابة الأمر التالي .ascii‏ 


VN 


A‏ اساسیات لینکس 


وإجابة على السؤال السابق فان جدول نص لغة ASCII‏ سيعرض الملفات التي تبدأ ب 1ء ۰4۰3۰2 ۰5 6 


۷۰ء :؛ < ات ۰۶۰ © روم 


دنا الاقتباس 


هناك ثلاثة أنواع من الاقتباسات التي تستخدمها قشرة الباش Bash shell‏ الأول هو علامة الاقتباس المفردة 
single quote‏ ( ' ) والثاني علامة الاقتباس المزدوجة double quote‏ ( " ) والأخیر هو علامة الاقتباس 
الخلفية back quote‏ ) ^( . العلامات السابقة لھا مميزات خاصة في قشرة الباش .Bash shell‏ 

لفهم علامة الاقتباس المفردة والمزدوجة فكر في المثال التالي» علامة النجمة asterisk‏ ) * ) تستخدم في 
القشرة كحرف ممیز glob‏ لکن كيف أقوم بإدخالھا على انها نص فقط؟ هنا تأتي فائدة علامات الاقتباس. 

علامة الاقتباس المفردة single quote‏ تمنع القشرة من تفسير interpreting‏ أو توسيع expanding‏ 
ARIS‏ الأحرف الخاصة. وغالبا ما تستخدم علامات الاقتباس المفردة لحماية سلسلة string‏ من التغيير بواسطة 
القشرة» بحيث يمكن تفسير سلسلة من أمر ما کمعامل parameter‏ 

وعلامة الاقتباس المزدوجة double quote‏ توقف القشرة من توسیع الأحرف Jis glob‏ النجمة asterisk‏ 
( * ) وعلامة الاستفهام question mark‏ ( ؟ ) وبين القوسين المربعين square brackets‏ ) ][ ). اذن 
علامة الاقتباس المزدوجة لا تسمح بتوسع المتغيرات variable expansion‏ واستبدال الأوامر 
.command substitution‏ 

آخیرا علامة الاقتباس الخلفية back quote‏ وهي لاستبدال الأوامر» بمعنى السماح للأمر بأن Mi‏ ضمن خط 
أمر آخر line of another command‏ . 

لاستخدام الاقتباس يجب ادخال زوجين من علامات الاقتباس في البداية وفي النهاية» والا فان القشرة ستتجاهل 
الأمر بالكامل. 

علامات الاقتباس مفيدة لمنع blocking‏ القشرة shell‏ من تفسیر interpreting.‏ الحروف » أيضا فان القشرة 
توفر وسيلة لمنع تفسير حرف وتسمى بالهروب escaping‏ . رمز الهروب escaping‏ هو "ا" ویستخدم 


في بداية الحرف. 


۷۸ 


M 
اساسیات لینکس‎ 7۳ 


۱ الخطوة‎ ٠,٥,١ 
داخل سطر‎ date مثال لتنفیذ الأمر‎ .) ۲ ( back quote الأمر التالي يظهر استخدام علامة الاقتباس الخلفية‎ 


الشر 660 م: 


echo Today is 6 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo Today is ۴ 


186181917 dis Tue Jem 19 15۰48650 URC “۹۹۶۵ 


وه : 


تنفیذ الأمر echo Today is date’‏ 
٤ ١‏ الخطوة Y‏ 
یمکنك وضع علامة الدولار 8 قبل وبعد الأمر لانجاز استبدال الأوامر :command substitution‏ 


echo Today is $(date) 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo Today is $(date) 


Today is Tue Jem 19 15:51:09 76, 


وه : 


echo Today is $(date) تنفیذ الأمر‎ 


لماذا اذن هناك طریقتین لعمل نفس الشيء؟ فعلامة الاقتباس الخلفية Backquote‏ تبدو مشابهة جدا لعلامة 


الاقتباس المفردة single quote‏ ( ' )۰ مما يجعل من الصعب إدراك ما بفترض بهما للقيام به. في الأضل 


۷۹ 


اساسیات لینکس 


استخدمت القشرة .backquotes‏ لکن في الإصدار الحديث من قشرة الباش Bash shell‏ تم إضافة تنسيق 


للأمر $(command)‏ لجعل الموضوع أكثر وضوحا. 


Y الخطوة‎ ٤٥٣ 


(ذا كنت Y‏ تريد استخدام علامة الاقتباس الخلفية Backquote‏ لتنفیذ الأوامر ضع علامة الاقتباس المفردة 


single quote‏ كما يلي: 


echo This is the command 6 ۲ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


echo Thus is the command Y ۵۱2۱۳2 ۲‏ در 


This is the command 65 


و : 


echo This is the command "date تنفيذ الأمر‎ 


٤ الخطوة‎ 5 


لاحظ أنه يمكنك أيضا وضع حرف مائل امام کل حرف 63610|0016. تنفیذ ما يلي: 


echo This is the command ۱ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ echo This is the command ۰ 


This is the command 6 


و : 


echo This is the command ۱۵۵6۱ تنفيذ الأمر‎ 


اساسیات لینکس 


٥ الخطوة‎ ٤٥٥ 


علامة الاقتباس المزدوجة Double quote‏ لا يكون له أي تأثير على حروف علامة الاقتباس الخلفية 


.backquote‏ وتستخدمها القشرة shell‏ کأوامر استبدال command substitution‏ كما يلي: 


echo This is the command ۰216 ۳ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


5 echo TALS is the 69900 V Cate 


Taig i6 the Commence. Tue Jam 19 16:05:41 UTC 2016 


و : 


echo This is the command "date" تنفیذ الأمر‎ 


٦ الخطوة‎ 7 


علامة الاقتباس المزدوجة double quote‏ ( ") تأثر على أحرف glob‏ وتعطل المعنی خاص بهم. نفذ التالي: 


echo D* 


echo DA 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


echo D*‏ و 


Desktop Documents Downloads 


5 echo WD 


echo "D*" «echo D* تنفیذ الأمرين‎ 


^Y 


2230 اساسیات لینکس‎ ps 


هام: قد تبدو علامات الاقتباس تافهة وغريبة في الوقت الراهن» ولكن كما اكتسبت المزيد من الخبرة في التعامل 


مع الأوامر» فسوف تکتشف أن فهم كيفية الاقتباس هو أمر بالغ الأهمية عند التعامل مع القشرة. 


1,£ جمل التحكم 


عادة عند كتابة أمر ما فانه ينفذ بالضغط على مفتاح Enter‏ تقدم قشرة الباش Bash shell‏ ثلائة جمل مختلفة 
يمكن استخدامها لفصل عدة أوامر multiple commands‏ مكتوبة معا. 

أبسط فاصل بين الأوامر هو الفاصلة المنقوطة semicolon‏ ( ؛ ). استخدام الفاصلة المنقوطة بین عدة أوامر 
تسمح بتنفیذها واحدا تلو الآخرء بالتسلسل من الیسار إلى الیمین. 

الاحرف 88 تستخدم لعمل جمل منطقية بحیث يتم تنفیذ آوامر مشروطة ومفصولة باستخدامها. إذا کان الأمر 
على يسار الحرفین 8,8 ناجحا سیتم تنفيذ باقي الجملة. والعکس صحيح فإذا فشل الأمر إلى يسار 88 فلا يتم 
تنفيذ تلك الجملة. 

نرى بعد ذلك الحرف || وايضا يستخدم لعمل جمل منطقية» وهو حرف تنفيذ شرطي وهذا التنفيذ يكون بشكل 
مفصول كل امر على حداء فإذا فشل الأمر في اليسار يتم التنفيذ. وإذا كان الأمر في يسار الحرف || غير متحقق 
سوف يتم التنفيد. 

لمعرفة كيفية عمل هذه جمل التحكم سنستخدم التالي: الصواب true‏ والخطأ false‏ الصواب دائما قابل للتنفيذ 
بينما الخطأ يفشل دائما. قد لا تتوفر أمثلة واقعية لكيفية عمل 9S‏ من جمل التحكم .88 و || من دون إدخال أوامر 


جديدة. 


151 ,£ القط ۱:2 


هنا سيتم تنفیذ الأوامر الثلائة التالية ولکن بشکل مفصول بواسطة الفاصلة المنقوطة :semicolons‏ 


echo Hello; echo Linux; echo Student 


اساسیات لینکس 


كما ترون تظهر النتائج لتنفيذ الأوامر الثلاثة بالتتابع: 


:~$ echo Hello; echo Linux; echo Student 


Hello 
Linux 


Student 


echo Hello; echo Linux; echo Student تنفیذ الأمر‎ 


Y الخطوة‎ ٤٢ 


الآن نضع ثلاث أوامر معا ونفصلها بفواصل منقوطة csemicolons‏ حيث ينفذ الأمر الأول مع نتيجة الخطأ: 


false; echo Not; echo Conditional 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ false; echo Not; echo Conditional 


Not 


Conditional 


false; echo Not; echo Conditional تنفیذ الأمر‎ 


لاحظ أنه في المثال السابق کل الأوامر الثلاثة تم تنفيذها على الرغم من أن الأمر الأول فشل Cus‏ لا تظهر نتيجة 
الأمر الخاطئ false‏ لذلك فان فصل الأوامر بالفواصل المنقوطة semicolons‏ ( : ) یجعلها مستقلة تماما 


عن بعضھا البعض, 


Y الخطوة‎ ٤٣ 


هنا سنستخدم Alas.‏ (و) and‏ للفصل بین الأوامر: 


۸٣ 


اساسیات لینکس 


echo Start 88 echo Going 88 echo Gone 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo Start && echo Going && echo Gone 


echo Start && echo Going && echo Gone تنفیذ الأمر‎ 


عندما تنفیذ جملة echo‏ بشکل صحيح aimi‏ إرجاع القيمة «value of success‏ مما يسمح للعبارة التالية 


بان يتم تنفيذها أيضا. 


٤ الخطوة‎ 56 


استخدم (و) and‏ مع الأوامر التي تفشل كما هو موضح آدناه: 


echo Success 88 false && echo Bye 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ echo Success && false && echo Bye 


Success 


تنفیذ الأمر echo Success && false && echo Bye‏ 
آول أمر echo‏ نجح ويمكن روية نتیجته. امر الخطأ false‏ نفذ والنتيجة هي الفشل وبالتالي لن يتم تنفيذ امر 


0 الاخير. 


^f 


س0 اساسيات لينكس 


٥ الخطوة‎ ٥ 


حرف (أو) 0۲ يفصل بین الأوامر التالية وهو الذي یوضح الفرق قبل وبعد استخدامه» ايضا إذا كانت أول عملية 


ناجحة فإنها تسبب عدم التنفیذ: 


false || echo Fail Or 


true || echo Nothing to see here 
وينبغي أن يكون التنفيذ مشابه لما يلي:‎ 


:-$ false 


echo Fail Or 


:~$ true || echo Nothing to see here 


وم : 


true || echo Nothing to see here «false || echo Fail Or تنفیذ الأمرین‎ 


٧‏ سجل القشرة 


تحتفظ قشر ة الباش Bash shell‏ على سجل تاريخي history‏ للوامر التي کتبت. تلك الأوامر Previous‏ 


۵5 بمکن الوصول الیها بسهولة وبعدة طرق. 


أول وأسهل طريقة لتذكر آمر سابق هي استخدام مفتاح السهم للأعلى up arrow Key‏ حيث ان كل مرة تضغط 
عليه تظهر أمر واحد» استمر بالضغط إلى ان تصل للامر الذي تريده. وعكسه مفتاح السهم لأسفل down‏ 


arrow key‏ حيث سوف يذهب إلى الأمام عبر السجل التاريخي history‏ للأمر الذي تریده. 


عندما تجد الأمر الذي ترید تنفیذه یمکنك استخدام مفاتیح الأسهم لليسار left arrow keys‏ ومفاتيح الأسهم 
لليمين right arrow keys‏ لوضع المؤشر عليه وتعديله. مفاتیح أخرى مفيدة للتعدیل مثل مفتاح البداية Home‏ 


والنهاية End‏ ومسافة للخلف Backspace‏ وحذف .Delete‏ 


اساسیات لینکس 


وهناك طريقة أخرى لاستخدام خاصية السجل هو كتابة امر السجل التاريخي history‏ لعرض قائمة بالأوامر 
السابقة مع الترقيم. الارقام الموجودة على يمين الأمر يمكن استخدامها لتنفیذ ذلك الأمر مرخ آخری. ايضا أمر 
السجل history‏ له عدد من الخيارات» وباستخدام تلك الخيارات يمكن التعديل بحيث تظهر الأوامر التي سيتم 


عرضها أو التي سيتم تخزينها. 
١‏ الخطوة ۱ 


نفذ الأوامر التالية ثم اكتب امر السجل :history‏ 


date 
clear 
echo Hi 


history 


تذکر: الأمر date‏ سيطبع الوقت والتاریخ على النظام. اما امر clear‏ فهو يزيل الأوامر من الشاشة. 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


echo Hi‏ کن 


:-$ history 


date 
clear 
echo Hi 


history 


history «echo Hi «clear «date تنفیذ الأوامر‎ 


۸ 


اساسیات لینکس 


عند التنفيذ؛ فمن المحتمل جداً أن تختلف آرقام الأوامر عن الأرقام المذكورة أعلاه. هذا لأنك على الأرجح قد 


نفات عددا مختلفا من الأوامر. 


Y الخطوة‎ ٤٣٢ 


یستخدم الأمر التالي لعرض عدد محدود من الأوامر» حيث يمكن لأمر السجل history‏ ان يعتبر عددا ما 


کمعامل parameter‏ لیقوم بعرضه. اكتب الأمر التالي لعرض الأوامر الخمس الماضية من السجل: 


history 5 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


5 ئ0 5 


false || Fail Or 

false || echo Fail Or 

true || echo Nothing to see here 
history 


MTS EOE VY 5 


تنفیذ الأمر 5 history‏ 


Y الخطوة‎ ۳ 


لتنفیذ الأمر مرة أخرىء اكتب علامة التعجب ! exclamation point‏ ورقم ذلك الأمر. على سبيل المثال نفذ 


:٤٩ الأمر‎ 


94 


لتنفيذ هنا كما يلي: 


۸۷ 
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94 ! رہ 


-bash: 94: command not found 


وه : 


تنفیذ الأمر 94 ! 
لاحظ أنه لم يظهر اي آمر لأننا لم نتب ٤٩‏ أمر في القشرة. 
٤‏ الخطوة ٤‏ 


بعد ذلكء جرب الوصول إلى سجل تاریخ الأوامر history‏ باستخدام مفاتیح الأسهم صعوداً up arrow keys‏ 
ومفاتیح الاسهم نزو لا down arrow keys‏ استمر بالضغط على مفتاح السهم للأعلى حتی تجد الأمر الذي 


ترید تنفیذه. عند الحاجة استخدم مفاتیح أخرى لتحریر الأوامر ثم اضغط على مفتاح الادخال Enter‏ لتنفيذها. 


۸۸ 


— We 
2030 یسپ اساسیات لینکس‎ 


سید ااب کد رب گانے بان 


aca‏ الان الحصون على اص 


Getting Help 


۸۹ 


230 اساسیات لینکس‎ ES 
کا ج‎ 
مقدمة‎ ١ 
هذا هو المعمل الخامس: الحصول على المساعدة. عن طريق أداء هذا التمرین» سوف تتعلم كيفية الحصول على‎ 
المساعدة في الأوامر وفي البحث عن الملفات.‎ 

ه استخدام عدة أنظمة مساندة للحصول على المساعدة في الأوامر. 

٭ تلم كيفية تحدید الأوامر. 
في هذه المهمة task‏ سوف نستكشف طريقة وكيفية الحصول على المساعدة help‏ في نظام لينكس. وهو امر 
مهم عندما تجد أنك عالق Stuck‏ في نقطة ما؛ أو عندما لا تستطيع أن تتذکر remember‏ كيف يعمل aM‏ 
الأوامر .command‏ 
بالإضافة إلى عمليات البحث searches‏ على الانترنت nternet‏ يوفر نظام التشغيل لینکس مجموعة متنوعة 
من التقنیات techniques‏ لمعرفة تفاصيل أكثر عن أمر ما command‏ أو ميزة معينة feature‏ ومما لا 
شك فيه ان معرفة هذه التقنيات المختلفة different‏ تسمح لك بالعثور find‏ على المعلومة التي تريدها JS‏ 
سرعة وسهولة .easily and quickly‏ 
Y, Y‏ الخطوة ١‏ 
تنفيذ الأوامر في وعاء باش عن طريق كتابة الأمر ثم الضغط على مفتاح Enter‏ على سبيل المثال» اكتب الأمر 
التالي لعرض تاريخ اليوم: 

016 
| i 


My 
اساسیات لینکس‎ TW 


يجب أن يكون التنفيذ مشابه لما يلي: 


gae date 


7۳03 Jem LY 17827220 UTC 2016 


وه : 


تنفیذ الأمر data‏ 


Y الخطوة‎ o, Y, Y 


لمعرفة المزید حول الأوامر» ادخل علی صفحات دلیل المستخدم manual page‏ اسطة .man X‏ على 


سبیل المثال نفذ الأمر التالي لمعرفة المزید عن الأمر :date‏ 


man date 


ویظهر الأمر في الموجھ كما يلي: 


:~$ man date 


الأمر man date‏ في الموجه 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


1١ 


AN‏ اساسیات لينكس 
User Commands‏ 


date - print or set the system date and time 


SYNOPSIS 
dale [QEON و و و‎ (1 


date [-u|--utc|--universal] [MMDDhhmm[ [CC] YY][.ss]] 


DESCRIPTION 


Display the current time in the given FORMAT. or set 
System date. 


--date-STRING 

display time described by STRING: not 7 
--file-DATEFILE 

like --date once for each line of DATEFILE 
--reference-FILE 


display the last modification time of FILE 


--rfc-2822 


output date and time in RFC 2822 format. Example: 


Mon. 07 Aug 


Manual page date(1) line 1 (press h for help or q to quit) 


man date تنفیذ الأمر‎ 


ملاحظة: الوثائق التي یتم عرضھا بالأمر man‏ يطلق علیهم اسم صفحات دلیل المستخدم manual‏ 


.page 


إذا استطاع الأمر man‏ العثور في دليل المستخدم manual page‏ لمعطيات «argument‏ عندها سيتم 


عرض النتائج باستخدام آمر يسمى أقل less‏ 


۹۲ 
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یصف الجدول table‏ التالي مفاتیح 3334 useful keys‏ تستخدم مع امر less Jif‏ ذلك للتحکم control‏ 


في إخراج العرض display output‏ كما يلي: 


المفتاح 

H أو‎  فرحلا‎ 

الحرف 0 أو Q‏ 

مفتاح المسافة Spacebar‏ أو مفتاح صفحة للأسفل 
PageDown‏ 

الحرف b‏ أو مفتاح صفحة للاعلی PageUp‏ 

مفتاح ادخال Enter‏ أو سهم للأسفل down arrow‏ 
سهم للاعلی Up arrow‏ 

حرف متبوع بنص للبحث text to search‏ 
حرف؟ متبوع بنص للبحث text to search‏ 

٣ حرف‎ 


حرف لا 


ui, 
عرض المساعدة‎ 
الخروج من المساعدة أو الصفحات دليل المستخدم‎ 


تحريك الشاشة للامام 


تحريك SUA‏ إلى الخلف 
تحرك سطر واحد للأسفل 

تحرك سطر واحد لاعلی 

البحث من البداية إلى الامام 

بدء البحث من الخلف 

الانتقال إلى النص التالي الذي یطابق البحث 


الانتقال إلى النص السابق الذي بطابق البحث 


جدول للمفاتيح المستخدمة مع امر less‏ أقل للتحكم في إخراج العرض 


Y الخطوة‎ o, Y, Y 


اکتب حرف [p‏ لتری قائمة من أوامر الحركة. بعد قراءة آوامر الحركة اكتب حرف q‏ للعودة إلى ARA,‏ كما 


av 
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SUMMARY OF LESS COMMANDS 


Commands marked with * may be preceded by a number. N. 


Notes in parentheses indicate the behavior if N is given. 


A key preceded by a caret indicates the Ctrl key; thus ^K is ctrl 


=R: 


Display this help. 


MOVING 
Forward one line (or N lines). 
AR Backward one line (or N lines). 
^w SPACE Forward one window (or N lines). 
٦ Backward one window (or N lines). 
Forward one window (and set window to N). 
Backward one window (and set window to N). 
ESC-SPACE Forward one window. but don't stop at 
end-of-file. 
Forward one half-window (and set half-window to 
N) 
Backward one half-window (and set half-window to 
N) 
ESC-) RightArrow * Left one half screen width (or N positions). 


HELP -- Press RETURN for more. or q when done 


تنفیذ الأمر h‏ 


كلما تعلمت المزید عن نظام التشغیل لینکس ستجد أن صفحات دلبل المستخدم 5 30 تعبر مصدر قیم 


للغاية للمعلومات. 


qé 


M 
اساسيات لینکس‎ ^W 


٤ الخطوة‎ ٤ 
ولا تلتف من الاسفل للاعلی. ابدأ البحث إلى‎ case sensitive عملیات البحث ليست حساسة لحالة الاحرف‎ 
بكتابة:‎ file الأمام لكلمة ملف‎ 


/file 


لاحظ أن ما ستكتبه سيظهر في الجزء الایسر السفلي من الشاشة. 


-r. --reference-FILE 


display the last modification time of FILE 


-R. --rfc-2822 


output date and time in REC 2822 format. Example: 


Mon. 07 Aug 


تنفیذ الأمر /file‏ 


٥ الخطوة‎ ٥ 


لاحظ أن النص المطابق لعملية البحث تم تمييزه باللون الابیض. يمكنك البحت عن التالي بالضغط على حرف N‏ 


أو الانتقال إلى النتائج السابقة بالضغط على حرف ۱: 


qo 


^N‏ اساسیات لينكس 


-f. --MAG-DATEIEN 


like --date once for each line of 27م‎ 


۰6-89 مع عده 7 6ع -- -r.‏ 


display the last modification time of 


-R. --rfc-2822 
output date and time in RIC 2822 format. Example: 
Mon. 07 Aug 


2006 1228394856 0600 


--rfc-3339-TIMESPEC 
output date and time in RFC 3339 format. 
TIMESPEC-' date'. ^seonds'. or `ns' for date and 
time to the indicated precision. 
Date and time components are separated by a 
single space: 


2006-06-07 12 23:45 22-016 210 


-S. --set-STRING 


set time described by STRING 


-u. --utc. --universal 


print or set Coordinated Universal Time 


--help display this help and exit 


Manual page date(1) line 18/204 24$ (press h for help or q to quit) 


۹٦ 
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٦ الخطوة‎ ٦ 


تستخدم اوامر الحركة movement commands‏ كما هو موضح سابقا (مثل استخدام مفتاح المسافة 
۲ للانتقال move down‏ إلى الشاشة التالية (one screen‏ لقراءة iaia‏ دليل المستخدم 
man page‏ مع الأمر date‏ عند الانتهاء من القراءة» اكتب الحرف 0 للخروج exit‏ من صفحة دلیل 


المستخدم. 
٧‏ الخطوة ۷ 


في بعض الحالات some cases‏ قد لا نتذکر remember‏ الاسم الدقيق exact name‏ لأمر ما 
0 عندها يمكن استخدام الخيار -k‏ مع الأمر man‏ في صفحات الدلیل manual page‏ ; والحصول 
على كلمة رئيسية Keyword‏ لذلك الأمر. على سبيل المثال تنفيذ الأمر التالي يعرض ملخص لجميع الصفحات 
دليل المستخدم man pages‏ التي لديها كلمة الرئيسية keyword‏ وهي كلمة " ٠" password‏ كما هو 


ظاهر في المثال التالي: 
man -k password‏ 


فيكون التنفیذ مشابه لما يلي: 
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sysadminGlocalhost:-$ man -k password 

chage (1) - change user password expiry information 

chgpasswd (8) update group passwords in batch mode 

chpasswd (8) update passwords in batch mode 

cpgr (8) copy with locking the given file to the 
222510926 ۹۶۹۹٦٣ 
copy with locking the given file to the 
19012 ۵ 23 ٣٥ 

expiry (1) check and enforce password expiration policy 

login.defs (5) shadow password suite configuration 

pam pwhistory PAM module to remember last passwords 

pam unix (8) Module for traditional password authentication 

passwd (1) change user password 

passwd (1ssl) compute password hashes 

passwd (5) the password file 

pwck (8) verify integrity of password files 

pwconv (8) convert to and from shadow passwords and 
groups 

shadow (5) shadowed password file 

shadowconfig (8) toggle shadow passwords on and off 

unix chkpwd (8) Helper binary that verifies the password of 


Tk‏ یی تا 


unix update (8) Helper binary that updates the password of a 


given user 
vipw (8) edit the password. group. shadow-password or 
shadow-gr... 


sysadminGlocalhost: ^$ 


man -k password تنفیذ الأمر‎ 


۹۸ 


أو على الأقل السماح بالمرور السريع easily scroll‏ على تلك البيانات though the data‏ في الوقت 
الراهن استخدام شریط التمریر scrollbar‏ على الجانب الأيمن on the right hand‏ من نافذة العرض 
terminal window‏ لتحريك الشاشة to move the display‏ صعوداً ونزولاً up and down‏ حسب 


.as needed الحاجة‎ 
۸ الخطوة‎ ۸ 


لاحظ أن الأمر apropos‏ هو طريقة أخرى another way‏ لعرض view‏ معلومات ملخصة 
5 عن كلمة رئيسية keyword‏ في صفحة دليل المستخدم «man page‏ اكتب الأمر التالي في 


موجهه الأوامر :prompt‏ 


apropos password 


]1 2 
E‏ % اساسیات لینکس 22030 

خيار -k‏ المصاحب للامر man‏ غالبا ما يكون له كمية 44S‏ $ من النتائج .huge amount of output‏ 

لذلك سوف نتحدث في معمل gaY‏ عن تقنيات technique‏ وذلك للحد من تلك النتائج limit this output‏ 

فيكون التنفیذ مشابه لما يلي: 


7۳۳ اساسيات لینکس 


sysadminGlocalhost:-«$ apropos password 
chage (1) - change user password expiry information 
chgpasswd (8) update group passwords in batch mode 
chpasswd (8) update passwords in batch mode 
cpgr (8) copy with locking the given file to the 
كدت ددهم‎ OE Gio Sc 
copy with locking the given file to the 
19012 ۵ 23 ٣٥ 
expiry (1) check and enforce password expiration policy 
login.defs (5) shadow password suite configuration 
pam pwhistory PAM module to remember last passwords 
pam unix (8) Module for traditional password authentication 
passwd (1) change user password 
passwd (1ssl) compute password hashes 
passwd (5) the password file 
pwck (8) verify integrity of password files 
pwconv (8) convert to and from shadow passwords and 
groups 
shadow (5) shadowed password file 
shadowconfig (8) toggle shadow passwords on and off 
unix chkpwd (8) Helper binary that verifies the password of 


Tk‏ یی تا 


unix update (8) Helper binary that updates the password of a 


given user 
vipw (8) edit the password. group. shadow-password or 
shadow-gr... 


sysadminGlocalhost: ^$ 


apropos password تنفیذ الأمر‎ 


ملاحظة: لیس هناك فرق بین الأمر man -k‏ والأمر apropos‏ حیث أنهما یؤدیان نفس الوظيفة. 


اساسیات لینکس 


۹ الخطوة‎ Y, 


غالبا ما تکون صفحات دليل المستخدم man pages‏ متعددة multiple‏ وبنفس الاسم .same name‏ 
على سبيل المثال» الأمر السابق أظهر ثلاث صفحات لكلمة "passwd"‏ نفذ Execute‏ الأمر التالي 
following command‏ لعرض view‏ كلمة "passwd"‏ ككلمة كاملة في صفحات دليل المستخدم màn‏ 


5 وليس كشرح لها داخل الصفحات: 


man - passwd 


فیکون التنفید مشابه لما بلي: 


:~$ man -f 0 
passwd (5) - the password file 


passwd (1) - change user password 


passwd (sel) - compute password hashes 


man -f passwd تنفیذ الأمر‎ 


ان وجود صفحات لدليل المستخدم different. 33534 man pages‏ لنفس الاسم same name‏ تكون 
مربكة confusing‏ لكثير من مستخدمي Users‏ لينكس الحدیئین. صفحات دليل المستخدم man pages‏ 
ليست فقط لأوامر لینکس ولكن أيضا لملفات النظام system files‏ وغيرها من المميزات features‏ الموجودة 
بنظام التشغیل Operating System‏ بالاضافة إلى ذلك يوجد في بعض الأحيان أمران يتشاركان نفس الاسم» 


كما في المثال المذكور أعلاه. 


صفحات دليل المستخدم المختلفة تتميز بوجود الأقسام 5 اافتراضيا هناك تسعة أقسام لصفحات دلیل 


:man pages المستخدم‎ 


. برامج قابلة للتنفيذ Executable programs‏ أو آوامر القشرة .shell commands‏ 
استدعاءات النظام System calls‏ (الوظائف functions.‏ التي توفرها النواة (kernel‏ 
استدعاءات المكتبة Library calls‏ (وظائف functions.‏ داخل مکتبات البرنامج). 

. ملفات خاصة Special files‏ (وعادة ما توجد في .(/dev‏ 

. صيغ واتفاقیات الملف «File formats and conventions‏ على سبیل المتال 
.etc/passwd/‏ 

Games ألعاب‎ 

. متفرقات Miscellaneous‏ (بما في ذلك الحزم الدقيقة macro packages‏ والاتفاقیات 
«(conventions‏ على سبيل المثال» man(7)‏ و .groff(7)‏ 

آوامر إدارة النظام System administration commands‏ (عادة تكون للجذر (root‏ 


.[Non standard [غير القياسية‎ Kernel routines روتین النواة‎ . 


عند كتابة أمر مثل man passwd‏ یتم البحث في القسم الأول» وإذا تم العثور على تطابق یتم عرض iaia‏ 
النتائج. الأمر man - passwd‏ يُظهر أن في القسم الأول 1 section‏ هناك صفحة دلیل المستخدم man‏ 


page‏ وتظهر كالتالي: )1( passwd: passwd‏ ونتيجة لذلك یتم عرضها بشكل افتراضي. 


ENA ك2‎ 


لعرض صفحات دلیل المستخدم لقسم Section‏ آخرء يجب توفر رقم ذلك القسم. على سبیل المثال: 


man 5 0 
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فیکون التنفید مشابه لما بلي: 


PASSWD(5) File Formats and Conversions 
PASSWD(5) 


NAME 


passwd - the password file 


DESCRIPTION 


/etc/passwd contains one line for each user account. with 
seven fields 


delimited by colons (":"). These fields are: 
login name 
optional encrypted password 
numerical user ID 
numerical group ID 
user name or comment field 
user home directory 


optional user command interpreter 


Manual page passwd(5) line 1 (press h for help or و‎ to quit) 


man 5 passwd تنفیذ الأمر‎ 


واد 
په اساسيات لينكس 


۹ه الخطوة ۱( 


بدلا من استخدام الأمر man f‏ لعرض کافة أقسام صفحة الدلیل للاسم» يمكنك استخدام الأمر ۷13118 وذلك 


لعرض ارقام الأقسام التي توجد بها الكلمة التي تبحث عنھاء کما هو موجود بالمثال التالي: 


whatis passwd 


فيكون التنفيذ مشابه لما يلي: 


:-$ whatis passwd 


passwd (5) - the password file 


passwd (1) - change user password 


passwd (1ssl) - compute password hashes 


whatis passwd تنفیذ الأمر‎ 


ملاحظة: لیس هناك فرق بين الأمر man -f‏ والأمر whatis‏ حيث انهما يقومان بنفس العمل. 


۶ الخطوة ۱۲ 


تقریبا كل ممیزات النظام system features‏ مثل الأوامر commands‏ ونظام الملفات system files‏ 
لدیها صفحات دلیل الاستخدام man pages‏ بعض هذه الممیزات features‏ لها مزایا أكثر نقدما تسمی 


صفحات المعلومات info pages‏ لرؤية ذلك نفذ الأمر التالي: 


info date 


فیکون التنفيذ مشابه لما بلي: 


ANS‏ اساسیات لينكس 


File: coreutils.info. Node: date invocation. Next: arch invocation.: 
Up: SystNem context 


SMO SCS ¢ 


dete OE LEONE ا مهم‎ [ 


date [-u|--utc|--universal] [ MMDDhhmm[[CC]YY][.ss] ] 


Invoking cerce” with no FORMAT argument is equivalent to invoking it 


with a default format that depends on the "LC TIME' locale category. 


21 


In the default C locale. this format is ۲+۵ 


eu the output looks like Thu Mear 3 13347551 PBST 2005". 


Normally: `date' uses the time zone rules indicated by the 
environment variable. or the system default rules if TA! is 


*Note Specifying the Time Zone with T2: (libc)TZ Variable. 


If given an argument that starts with a +۲ 0216۲ prints the 
current date and time (or the date and time specified by the '--date' 
--zz-Info: (coreutils.info.gz)date invocation. 41 lines Top 


Welcome to Info version 4.13. Type h for help. m for menu item. 


info date تنفیذ الأمر‎ 


يرى العديد من مستخدمي لینکس ان صفحات المعلومات info pages‏ أسهل في القراءة. وهي غالبا ما تكون 


مكتوبة على دروس تعليمية ۱685005 uis‏ تتم كتابة صفحات دليل المستخدم بصيغة وثائق للنظام. 


وو 
E‏ اساسیات لینکس 2750 
۳ الخطوة ۱۳ 
أثناء عرض iaia‏ معلومات info page‏ من الخطوة السابقة اکتب حرف h‏ لتری قائمة من أوامر الحركة 
movement commands‏ لاحظ أنها مختلفة عن أوامر الحركة المستخدمة في .man pages‏ بعد قراءة 
أوامر الحركةء اكتب حرف ل (] ) للعودة إلى عرض الوثيقة. 
Y,1£‏ ,0 الخطوة ۱۶ 
استخدم أوامر الحركة movement commands‏ لقراءة صفحة المعلومات info page‏ الخاصة بالأمر 
6 . عند الانتهاء ضع المؤشر cursor‏ بأي مكان على السطر "Examples of date:"‏ ثم اضغط 
على مفتاح الادخال Enter‏ سيتم عرض وثيقة جديدة تبين أمثلة من امر التاريخ .date‏ 
65 الخطوة ٥١‏ 
اضغط على حرف ل ( | ) للعودة إلى الشاشة السابقة. عند الانتهاء من القراءة» اكتب حرف q‏ للخروج من صفحة 
معلومات info page‏ 
5 ,0 الْخطوة ۱۰ 
وهناك طريقة أخرى للحصول على مساعدة عن طريق اسناد الخيار --help‏ إلى أمر ما. معظم الأوامر تسمح 
لك بتمرير الخيار help‏ - - وذلك لعرض كيفية استخدام الأوامر الأساسية «basic command‏ كما يظهر 
في المثال التالي: 

date --help 
فيكون التنفيذ مشابه لما يلي:‎ 

ل7 | 
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sysadmin@localhost:~$ date --help 


Usage: date [OPTION]... [*FORMAT] 
EE date [-u|--utc|--universal] [MMDDhhmm[ [CC] YY][.ss]] 


Display the current time in the given FORMAT. or set the system date. 


-d« --date-STRING display time described by STRING. not 
"now' 
-f. --file-DATEFILE like --date once for each line of 
DATEFILE 
-r. --reference-FILE display the last modification time of 
80 0 
د يت‎ EEE C= 222 output date and time in RFC 2822 format. 
Example: Mon. 07 Aug 2006 12:34:56 -0600 
= ree OO SE TP ۱۱/۱۵ S EEG output date and time in RFC 3339 format. 
TIMESPEC-' datet: ^seconds'. or ns! for 
date and time to the indicated precision. 
Date and time components are separated by 
a single space: 2006-08-07 12:34:56-06:00 
SS: --Set-STRING set time described by STRING 
-u« --utc. --universal print or set Coordinated Universal Time 
--help display this help and exit 


--version output version information and exit 


date --help تنفیذ الأمر‎ 


۷ الخطوة ۱۷ 


بعض مميزات النظام system features‏ لدیها 3355( مساعدة help documents‏ آکثر تفصیلا وموجودة 
في المرجع directory‏ التالي /usr/share/doc‏ نفذ الأمر التالي لعرض محتویات هذه الوثيقة 


:document 


ls /usr/share/doc 


فیکون التنفيذ مشابه لما بلي: 


libxil-data 


libxau6 
libxcb1 
libxdmcp6 
libxext6 
libxml2 
libxmuul 
locales 


login 


logrotate 


lsb-base 
makedev 
man-db 
mawk 

mc 


mc-data 


mime-support 


mlocate 


module-init-tools 


اساسیات لینکس 


:-5 ls 5۳26/0 


libdrm2 

libedit2 

libelfi 

libffi6 

libgcci 

libgcryptill 
libgdbm3 

libgeoipl 
libgettextpoO 
libglib2.0-0 
libgnutls26 
libgompl 
libgpg-error0 
libgpm2 
libgssapi-krb5-2 
libgssapi3-heimdal 
libhcrypto4-heimdal 
libheimbasel-heimdal 


libheimntlm0-heimdal 


ls /usr/share/doc تنفیذ الأمر‎ 


adduser 

apt 

ascii 
base-files 
base-passwd 
bash 

bind9 
bind9-host 
bind9utils 
bsdmainutils 
bsdutils 
busybox-initramfs 
bzip2 
ca-certificates 
coreutils 

cpio 

cron 

curl 


dash 


لاحظ آنه في جمیع الحالات تقریباء توفر صفحات دلیل المستخدم man pages‏ وصفحات المعلومات info‏ 


5 المعلومات التي تحتاجها. ومع ذلك إذا كنت بحاجة إلى مزيد من المعلومات المتعمقة کاحتیاجات خاصة 


لمسؤولي النظام administrators sometimes‏ فإنك قد تجد هذه المعلومات في الملفات الموجودة في 


Jusr/share/doc كالتالي‎ directory المرجع‎ 


اساسیات لینکس 


٣‏ ایجاد الملفات 


في هذه المهمة» سوف نستكشف كيفية البحث search‏ عن الملفات files‏ في النظام System‏ وهي خاصية 
مفيد في حالة عدم التمكن من العثور على ملف في النظام» سواء قمت بانشاء هذا الملف أو تم انشاوه من قبل 


شخص آخر. 


1( الخطوة ۱ 


طريقة سهلة للبحث عن ملف باستخدام امر الموقع locate command‏ . على سبیل المثال يمكنك العتور على 


موقع الملف crontab‏ عن طریق تنفیذ الأمر التالي: 


locate crontab 


فیکون التنفید مشابه لما بلي: 


:-$ locate crontab 
/etc/crontab 


/usr/bin/crontab 


/usr/share/doc/cron/examples/crontab2english.pl 


/usr/share/man/manl/crontab.1l.gz 


/usr/share/man/man5/crontab.5.gz 


:~$ 


locate crontab تنفیذ الأمر‎ 


Y الخطوة‎ ٣٢ 


لاحظ أن التنفيذ السابق يتضمن کل الملفات التي تحتوي على کلمة crontab‏ کجزء من اسمها. للبحث عن 


الملفات التي اسمها فقط e" crontab"‏ استخدم الأمر التالي: 


A‏ اساسیات لينكس 


locate -b ^crontab" 


فیکون التنفيذ مشابه لما بلي: 


:-$ locate =b "Ncrontab"  /etc/crontab 


/usr/bin/crontab 


تنفیذ الأمر locate -b "crontab"‏ 
ملاحظة: الأمر موقع locate‏ يستخدم قاعدة بيانات database‏ يتم تحدیثها updated‏ عادة مرة واحدة 
یومیا (عادة عند منتصف اللیل). تحتوي قاعدة البیانات تلك database‏ على قائمة بجمیع الملفات المحدثة التي 


على النظام. 


ونتيجة لذلك فان أي ملفات جديدة تم إنشاتها الیوم لن تکون موجودة عند البحث مع الأمر locate ei sa‏ إذا کان 
لديك وصول access‏ إلى النظام کمستخدم اساسي root user‏ (حساب مسوول النظام the system‏ 
administrator account‏ فیمکنك تحدیث هذا الملف یدویا manually‏ عن (b‏ تشغیل الأمر 
updated‏ عادة لا یمکن للمستخدمین العادیین regular users‏ تحدیث ملف قاعدة البیانات database‏ 


file 


طريقة أخرى للبحث عن الملفات الجديدة newer files‏ عن طريق كتابة الأمر find‏ يبحث هذا الأمر عن 
الملفات المباشرة live filesystem‏ بدلا من قاعدة البيانات الثابتة static database‏ وسنرى هذا الأمر 


في المعامل القادمة. 


۳ لخطوة‎ |o, Y Y 


إذا كنت ترغب فقط في معرفة أين موقع أمر ما فیمکنك تحقيق ذلك مع الأمر whereis‏ 


whereis passwd 
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فیکون التنفيذ مشابه لما بلي: 


$ whereis passwd 


passwd: /usr/bin/passwd /etc/passwd /usr/share/man/manl/passwd.1.gz / 


usr/share/man/manil/passwd.1ssl.gz /usr/share/man/man5/passwd.5.gz 


$ 


whereis passwd تنفیذ الأمر‎ 


الأمر whereis‏ يبحث فقط عن !5 4» commands‏ وصفحات دليل المستخدم man pages‏ ولیس عن 


الملفات 1165. 


SS‏ آن هناك آکثر من passwd man page‏ على النظام. لذلك و عند تنفیذ الأمر السابق نری آسماء ملفات 
متعددة multiple file names‏ في صفحات دلیل المستخدم man pages‏ (الملفات التي تنتهي في .02 هي 


2230 اساسيات لينكس‎ AE 


المعمل السادس — العمل مع الملفات والمراجم 


Working with Files and Directories 


۱ 


۱۳ 


[Es] 


و اساسیات لینکس 2230 


هذا هو المعمل السادس: قائمة الملفات والدلائل. عن طريق آداء هذا التمرین» سوف تتعلم كيفية التنقل وإدارة 


الملفات والدلائل. 
٭ قائمة الملفات والدلائل. 
LJ‏ نسخ ونقل وحذف الملفات والدلائل. 


۲ الملفات والمراجع 


في هذه المهمة سوف تستكشف مفاهيم الملفات files‏ والمراجع أو الدلائل directories‏ . 


في نظام التشغیل لینکس Linux OS‏ يتم تخزين البیانات data‏ في ملفات files‏ وتخزين الملفات في الدلائل 
68 يمكنك أن تستخدم المصطلح المجلدات folders‏ لوصف الدلائل directories‏ 

الدلائل directories‏ هي في الواقع ملفات files‏ أيضا؛ والبيانات data‏ التي تحتویها هي أسماء للملفات التي 
تم إدخالها فيهاء وهي توجد جنبا إلى جنب مع inode number‏ (وهو رقم معرف فرید یخصص لکل ملف) 
لمعرفة مكان وجود البيانات لهذا الملف على القرص. 

كمستخدم لنظام لینکس سوف تحتاج إلى معرفة كيفية التعامل مع هذه الملفات والدلائل» بما في ذلك كيفية عرض 
قائمة [ist‏ بالملفات files‏ في دليل directory‏ والقيام بالتحكم فيها من نسخ copy‏ وحذف delete‏ 


move OS s‏ لتلك الملفات. 


تحذیر: أسماء الملفات files‏ والدلائل directories‏ في لينكس حساسة لحالة الأحرف .case sensitive‏ 


وهذا يعني أن ملف یسمی ABC"‏ " لا يمكن ان نطلق عليه abc"‏ ". 
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۱ الخطوة ١‏ 
اكتب الأمر التالي لطباعة دليل العمل :working directory‏ 


pwd 


فیکون التنفيذ مشابه لما بلي: 


/home/sysadmin 


تنفیذ الأمر pwd‏ 


دلیل العمل working directory‏ هو الدليل الذي تعمل عليه حالياء أي ان النافذة الخاص به وتسمی terminal‏ 
تعمل حاليا. وهذا ما يسمى أيضا بالدليل الحالي „current directory‏ هذه المعلومة تعتبر مهمة وذلك لأنه 
عندما تقوم بتشغيل الأوامر مستقبلا سوف تستجيب لتلك الأوامر بشکل مختلف؛ اعتماداً على الدليل الذي تتواجد 


فيه حاليا. 


تنفيذ الأمر pwd‏ في المثال أعلاه هو المسار /home/sysadmin‏ ویمثل Bal‏ المائل الأول الدليل الجذر 


directory structure وهو أعلى مستوى في بنية الدليل‎ root directory 


في التنفيذ أعلاہ home‏ هو directory dh‏ تحت الدليل الجذر «root directory‏ ودليل sysadmin‏ 


تحت دليل .home‏ 


عند فتح نافذة terminal‏ ستضعك في دليلك الرئيسي your home directory‏ وهو الدليل الذي لديك 
الحق في الوصول الكامل full access‏ له اما بقية المستخدمين عادة لا يصلون اليه. لرؤية المسار path‏ 


للدليل الرئيسي الخاص بك؛ يمكنك تنفيذ الأمر التالي لعرض قيمة :HOME variable‏ 


echo $HOME 
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ويكون التنفيذ مشابه لما يلي: 


:~$ echo $HOME 


/home/sysadmin 


echo $HOME تنفیذ الأمر‎ 


۲ العطية ۷ 


يمكنك استخدام الأمر cd.‏ مع المسار path‏ ( / ) لتغییر الدلیل الحالي current directory‏ اکتب الأمر التالي 
لجعل الدلیل الجذر root directory‏ دلیل العمل الحالي current working directory‏ الخاص «dh‏ وتحقق 


:pwd مع الأمر‎ 
cd / 
pwd 


ویکون التنفيذ مشابه لما يلي: 


pwd «cd / تنفيذ الأمرين‎ 


Y الخطوة‎ ۳ 


للرجوع إلى دليلك your home directory‏ استخدم الأمر cd.‏ والذي يمكن تنفیذہ بدون مسار ( / ). التغيير 


إلى دليلك الرئيسي your home directory.‏ والتحقق عن طريق كتابة الأوامر التالية: 


اساسیات لینکس 


cd 


pwd 


ويكون التنفيذ مشابه لما يلي: 


/home/sysadmin 


تنفيذ الأمرين ۰60 pwd‏ 


لاحظ التغيير في الموجه prompt‏ یمثل الحرف تیلدا )~( دليلك الرئيسي .your home directory‏ ويقوم 


الموجه prompt‏ باطلاعك على الدليل الذي تتواجد فيه حاليا. 


٤ الخطوة‎ ٤ 


الأمر cd‏ مع المسار path‏ ( / ) يأخذك إلى دليل محدد. تنفيذ الأمر cd‏ مع دليل /home‏ عن طريق كتابة 


الأمر التالي: 


06 


pwd 


ویکون التنفيذ مشابه لما يلي: 


:~$ cd 6 


$ pwd 


pwd «cd / home تنفیذ الأمرین‎ 


Bh! 


A‏ اساسیات لینکس 


المسار المطلق absolute path‏ هو المسار الذي يُكتب كاملا مع الأمر 60 وذلك باضافة علامة المسار وهي 
مستقيم مائل للأمام forward slash‏ (/). المسارات المطلقة هي دائما مسارات كاملة من الدليل الجذر root‏ 


directory‏ إلى الدليل الفرعي sub-directory‏ أو الملف file‏ الذي تريد العمل عليه. 
٥‏ الخطوة ٥‏ 
تتم العودة إلى دليلك الرئيسي your home directory‏ باستخدام الأمر 00 مع تيلدا (-): 


cd ~ 


pwd 


ويكون التنفيذ مشابه لما يلي: 


/home/sysadmin 


pwd «cd ~ تنفيذ الأمرين‎ 


عند كتابة الأمر cd.‏ مع حرف تيلدا tilde‏ (-)» تقوم النافذة الطرفية terminal‏ بالانتقال إلى الدليل الرنيسي 


home directory‏ لحساب المستخدم على النظام. 

اما عند عدم وجود علامة ( / ) ء سيتم التوسع والذهاب إلى المسار المکتوب للمستخدم النشط حاليا Current‏ 
user 6‏ في القشرة .shell‏ 

وإذا كان اسم المستخدم User name‏ يتبعه مباشرة حرف تيلدا tilde‏ )~( » فان القشرة ستوسع منطقة تیلدا 


)~( واسم المستخدم user name‏ إلى الدليل الرئيسي home directory‏ لهذا المستخدم. على سبيل المثال» 


Jhome/bob ستتوسع إلى‎ «bob 
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وتعتبر المسارات paths‏ التي تبدأ مع تيلدا tilde‏ )~( مسارات مطلقة absolute paths‏ لأنه بعد ان تقوم 


القشرة shell‏ بتوسيع مسار تيلدا stilde path‏ يتم تشکیل المسار المطلق .absolute path‏ 
٦‏ الخطوة ٦‏ 
استخدم الأمر echo‏ آدناه لعرض بعض الأمثلة لاستخدام تيلدا tilde‏ )~( کجزء من مسار path‏ : 


echo ~ -sysadmin -root ^mail ٧ 


ویکون التنفيذ مشابه لما يلي: 


:~$ echo ~ «sysadmin -root ~mail -nobody 


/home/sysadmin /home/sysadmin /root /var/mail /nonexistent 


$ 


echo ~ ~sysadmin ~root ~mail ~nobody تنفيذ الأمر‎ 


۷ الخطوة ۷ 


التغيير إلى الدليل الرنيسي home directory‏ للمستخدم الجذر root user‏ عن طريق كتابة الأمر التالي: 


cd ~root 


ویکون التنفيذ مشابه لما يلي: 


SS cd -root 


-bash: cd: /root: Permission denied 


:~$ 


cd ^root تنفیذ الأمر‎ 
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لاحظ رسالة الخطأ error message‏ حيث تشير إلى أن القشرة حاولت تنفيذ الأمر 60 ثم فشلت بسبب رفض 
الإذن «permission being denied‏ وذلك لأنك في حساب المستخدم Sysadmin‏ وسوف تتعلم المزید 


Adag ب"‎ 


باستخدام المسار المطلق «absolute path‏ اذهب إلى الدلیل /usr/bin‏ ثم اعرض دليل العمل working‏ 


۷ء استخدام الأوامر التالية لتنفیذ ذلك: 


cd /usr/bin 


pwd 


ويكون التنفيذ مشابه لما يلي: 


:-$ cd /usr/bin 


$ pwd 


/usr/bin 


pwd «cd /usr/bin تنفیذ الأمرين‎ 


4691551 3, Y, 4 


استخدم المسار المطلق absolute path‏ لتغییر الدلیل /usr‏ وعرض Jus‏ العمل working directory‏ 


وذلك عن طريق الأوامر التالية: 


cd /usr 


pwd 
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ویکون التنفيذ مشابه لما يلي: 


S gel /USE 


$ pwd 


pwd «cd /usr تنفیذ الأمرين‎ 


٠١ الخطوة‎ ۰ 


استخدم المسار المطلق absolute path‏ للذهاب إلى الدليل /usr/share/doc‏ وعرض Ju‏ العمل 


working directory‏ عن طريق الأوامر التالية: 


cd ۱0 


pwd 


ویکون التنفيذ مشابه لما يلي: 


$ cd 6 


$ pwd 


/usr/share/doc 


تنفیذ الأمرين pwd «cd /usr/share/doc‏ 
المسار المطلق Absolute‏ مقابل المسارات 4:43 :Relative path names‏ 
لنفترض آنك في الدلیل /usr/share/doc‏ وتريد أن تذهب إلى الدليل /usr/share/doc/bash‏ اكتب الأمر 


7 0 في مثل هذه الحالةه استخدام المسار النسبي relative pathnames‏ للذهاب 


إلى ذلك الدلیل أو الملف. 
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مع المسارات النسبية relative pathnames‏ یتم كتابة الموقع الذي تريد الذهاب اليه من الموقع الحالي ولیس 
من بداية المسار مثل المسار المطلق. وتوضح الامثلة التالية كيفية استخدام المسارات النسبية relative‏ 


.pathnames 


١١ القطية‎ EN 


باستخدام المسار النسبي «relative path‏ اذهب إلى الدليل /usr/share/doc/bash‏ وقم بعرض دليل 


العمل working directory‏ عن طريق الأوامر التالية: 


cd bash 


pwd 


ویکون التنفيذ مشابه لما يلي: 


/usr/share/doc/bash 


pwd «cd bash تنفیذ الأمرين‎ 


ملاحظة: إذا لم یکن هناك دلیل باش bash directory‏ تحت الدلیل الحالي «current directory‏ فان 


الأمر السابق سوف يفشل. 


۱۲ الخطوة‎ ٣ 


استخدم المسار النسبي relative path‏ للتغییر من الدليل أعلاه والعودة للخلف خطوة واحدة فقط: 


اساسیات لینکس 


cam 


pwd 


ويكون التنفيذ مشابه لما يلي: 


/usr/share/doc 


pwd cd .. تنفيذ الأمرين‎ 


تمثل النقاط ) .. ( مستوى واحد أعلى عن موقع الدليل الحالي» وبالتالي Ya‏ من ان تكون في الدليل 


Jusr/share/doc إلى الدلیل‎ c3 /usr/share/doc/bash 


۳ الخطوة ۱۳ 


استخدم المسار النسبي relative path‏ للذهاب إلى مستوی واحد للاعلی one level up‏ من الدلیل الحالي 


ccurrent directory‏ ثم قم بالذهاب إلى الدلیل dict‏ عن طریق المسار النسبي: 


cd ../dict 


pwd 


ویکون التنفيذ مشابه لما يلي: 


/ 22/2722 2/277۳ 


pwd «cd ../dict. تنفيذ الأمرين‎ 


٢٢۲ 
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وهنا نلاحظ انه تم القيام بعملين في نفس سطر الأوامر وهما العودة مستوی واحد للاعلی ثم الذهاب عن طريق 


المسار النسبي إلى الدلیل .dict‏ 

۳ سرد الملفات والادلة 

في هذه المهمة سوف تتعلم كيفية سرد الملفات files‏ والدلائل „directories‏ 
د القطوة ؟ 

لسرد محتويات الدليل الحالي «current directory‏ استخدم الأمر ls‏ 


cd 


ویکون التنفيذ مشابه لما يلي: 


تنفيذ الأمرين «cd‏ کا 


عند تنفيذ الأمر وا تم وضع أسماء الدلائل باللون الأزرق الفاتح. وهي ميزة تلقائية توفرها العدید من توزيعات 


o. Su distributions‏ من خلال ميزة تدعی الاسم المستعار alias‏ وهو ما سنراه في معامل لاحقة. 


يدل اللون على نوع هذا العنصر item‏ يصف الجدول التالي بعض الألوان الاکثر شيوعا في أنظمة لینکس: 
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اللون نوع الملف 


Regular file ملف عادي‎ | Black or White اسود أو ابيض‎ 


ازرق Blue‏ ملف دلیل Directory file‏ 
سماوي Cyan‏ ملف ارتباط رمزي Symbolic link file‏ (ملف یشیر إلی ملف آخر) 
اخضر Green‏ ملف قابل للتنفيذ AKA program d Executable file‏ 


جدول یوضح أشهر الالوان في توزیعات لینکس 


Y الخطوة‎ ٢۲ 


لا یتم عرض جميع الملفات files‏ بشكل افتراضي by default‏ هناك ملفات تسمی الملفات المخفية hidden‏ 
5 والتي لا يتم عرضها بشكل افتراضی. لعرض كافة الملفات بما في ذلك الملفات المخفية» استخدم الخیار 


s مع الأمر‎ -a 


ويكون التنفيذ مشابه لما يلي: 


:~$ ls -a 


.bashrc .Selected editor 


.bash logout  .profile 


:-5 


ls —a تنفيذ الأمر‎ 


الملفات المخفية hidden files‏ تبدأ بنقطة dot‏ ( . ) وعادة هذه الملفات والدلائل يتم إخفائها لأنها ملفات لا 


تُطلب عادة. 
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على سبيل المثال» ملف /03511. المُبين في المثال أعلاه يحتوي على معلومات التکوین configuration‏ 


60 لقشرة الباش bash shell‏ فهذا الملف لا نحتاج إلى عرضه بشكل منتظم. 


هناك ملفين مهمين من الملفات ذات النقط dot files‏ موجودة في كل دليل «directory‏ الأول ذا نقطة واحدة 
وهو ( . ) ویمثل الدليل الحالي current directory‏ اما الثاني فهو ذا نقطتين ( .. ) ويمثل الدليل الاعلى من 


الدليل الحالي. 
۳ الخطوة Y‏ 


الأمر كا في حد ذاته يوفر فقط أسماء الملفات والدلائل files and directories names‏ داخل الدليل 


المحدد أو الحالي. نفذ الخيار التالي [- لمعرفة كيف يوفر مزيد من المعلومات حول الملف: 
ls -l /etc/hosts‏ 


ویکون التنفيذ مشابه لما يلي: 


:~$ وا‎ -l /etc/hosts 


-rw-r--r-- 1 root root 150 Jan 22 15:18 958 


وه : 


تنفیذ الأمر ls -L/etc/hosts‏ 
إذناً ما معنی کل المخرجات output‏ السابقة ؟ 


يقدم الجدول التالي وصفاً موجزاً لكل جزء من مخرجات الأمر [S‏ مع الخیار ا-: 
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تنفیذ ls -l‏ معنی التنفیذ 
علامة 0- علامة - تشير إلى العنصر هو ملف عادي «plain file‏ 


أما إذا رأينا حرف d‏ فانه يشير إلى ان العنصر هو دليل directory‏ 


„permissions of the file أذونات الملف‎ Jis هذا‎ ۳١۸/-٣--٣-- 
.hard link count ll الارتباط‎ axe وهذا يمثل ما يسمى‎ 1 
.user owner of the file المالك المستخدم للملف‎ root 
.group owner of the file مجموعة المالکین للملف‎ root 
.size of the file in bytes حجم الملف بالبايت‎ 189 


.The date/time of last modified تاریخ / وقت لاخر تعدیل في ملف‎ | Dec 12 16:14 


جدول يوضح تنفيذ ls -l‏ 


۳۶ الخطوخ £ 


آحیانا كنت تريد أن تری محتویات الدلائل jill‏ عية subdirectories‏ ولیس فقط محتویات الدلیل. يمكنك 


استخدام الخیار -R‏ لعمل ذلك كما يلي: 


ls - ۷ 


ویکون التنفیذ مشابه لما يلي: 


:-$ وا‎ -R ۲ 
/etc/udev: 
udev.conf 


/etc/udev/rules.d: 


70-persistent-cd.rules README 


و : 


ls -R /etc/udev تنفیذ الأمر‎ 
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الخیار -R‏ يشير إلى التکرار recursive‏ وبالتالي سيتم عرض كل الملفات في الدليل AUS  /etc/udev‏ كافة 


الملفات في الادلة الفرعية «subdirectory‏ هنا الدليل الفرعي هو rules.d‏ . 


كن حذرا عند التعامل مع الخيار -R‏ فبعض الدلائل كبيرة جدا! 
٥‏ الخطوة ه 


يمكنك استخدام رموز (wildcards) globbing‏ للحد من عدد الملفات آو الدلائل. علی سبیل المتال» یمکن 
لعلامة النجمة( * ) مطابقة صفر أو أکثر من أحرف اسم الملف. نفذ الأمر التالي لعرض الملفات التي fas‏ بالحرف 


و فقط في دليل etc‏ 
ls -d ۴‏ 
ویکون التنفیذ مشابه لما يلي: 


:-$ وا‎ -0 /etc/s* 


/etc/securetty / etc/ shells /etc/sysctl.conf 


/etc/shadow /etc/sudoers 


/etc/services  /etc/shadow- 


وم : 


تنفيذ الأمر -d /etc/s*‏ کا 


لاحظ أن الخیار -d‏ يمنع عرض الملفات من الدلائل الفر عية subdirectories‏ وينبغي دائما أن تستخدم الأمر 


.globbing عند استخدام رموز‎ [S 


واد 


۰7 الخطوة ٦‏ 
علامة الاستفهام ( ؟ ) يمكن استخدامها لمطابقة حرف واحد من اسم الملف. نفذ الأمر التالي لعرض كافة الملفات 
في الدلیل /etc‏ والمكونة من أربعة أحرف بالضبط: 


ls -00 09 


ويكون التنفيذ مشابه لما يلي: 


:-$ ls -d /etc/???? 


ls -d /etc/?2?? تنفيذ الأمر‎ 


V الخطوة‎ ۷ 


باستخدام الأقواس المربعة square brackets‏ ) [ ] ) یمکنك تحدید حرف واحد للمطابقة من مجموعة من 


الأحرف. نفذ الأمر التالي لعرض كافة الملفات في الدليل ete‏ التي تبدأ بأحد الحروف: ۰2 «C «b‏ : 


ls —d /etc/[abcd]* 


ویکون التنفيذ مشابه لما يلي: 
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sysadminGlocalhost:-$ ls -d /etc/[abcd]* 

/etc/adduser.conf /etc/blkid.conf /etc/cron.weekly 
/etc/adjtime /etc/crontab 
/etc/alternatives /etc/ca-certificates /etc/dbus-1 
/etc/apparmor.d /etc/ca-certificates.conf  /etc/debconf.conf 
/etc/apt /etc/calendar /etc/debian version 


/etc/bash.bashrc /etc/cron.d /etc/default 


/etc/bash completion.d  /etc/cron.daily /etc/deluser.conf 


/etc/bind /etc/cron.hourly /etc/depmod.d 
/etc/bindresvport.blacklist ^ /etc/cron.monthly /etc/dpkg 


sysadminGlocalhost: ^$ 


ls —d /etc/[abcd]* تنفيذ الأمر‎ 


٤‏ نسخ ونقل وإعادة تسمية الملفات والدلائل 


في هذه المهمةء سنقوم بنسخ copy‏ ونقل move‏ وإزالة remove‏ الملفات والدلائل. 
١‏ الخطوة ١‏ 


قم بعمل نسخة من ملف /etc/hosts‏ وضعه في الدليل الحالي current directory‏ ثم قم بسرد list‏ محتويات 


الدليل الحالي contents of the current directory‏ قبل وبعد نسخة: 


ls 
cp /etc/hosts hosts 


ls 


س0 اساسیات لینکس 
ویکون التنفيذ مشابه لما يلي: 


ls‏ و ه: 


:-$ cp /etc/hosts hosts 


وا $-: 


ls «cp /etc/hosts hosts «ls »« 5! تنفیذ‎ 


لاحظ کیف ان الأمر الثاني وا یعرض نسخة من ملف .hosts‏ 


Y الخطوة‎ ٦٤٦٢ 


الآن سنقوم بإزالة الملف «remove the file‏ ثم نسخه copy‏ مرة آخری» ولكن هنا النظام سیقوم بعرض 
الحدث. يتم ذلك باستخدام الخيار -v‏ أو .-—-verbose‏ قم بكتابة الأوامر التالية: 

rm hosts 

ls 

cp —v /etc/hosts hosts 

ls 

لاحظ أنه يتم إستخدام الأمر rm‏ لحذف delete‏ الملف. وسيتم توفير مزيد من المعلومات حول هذا الأمر في 

وقت لاحق هذا المعمل. 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


جو E‏ 
7۳ اساسيات لينكس 


8-72 rm hosts 


وا $-: 


:-$ cp -v /etc/hosts hosts 


^/etc/hosts' => “hosts! 


:-$ ls 


تنفیذ الأوامر «cp —v /etc/hosts hosts «ls «rm hosts‏ کا 


لاحظ أن -v‏ يبدل عرض المصدر source‏ والهدف target‏ عند تنفیذ الأمر .Cp‏ 


Y الخطوة‎ ٤٣ 


آدخل الأوامر التالية لنسخ الملف /etc/hosts‏ وذلك باستخدام النقطة period‏ (.) للإشارة إلى الدليل الحالي 


:target كهدف‎ current directory 


rm hosts 


ls 


cp —v /etc/hosts . 


ls 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


۳۳ 


اساسیات لینکس 


5265 rm hosts 


وا $-: 


- ۵۵۵/۱۵۵68 ۶ک ej‏ جو 


* /رهتات/‎ orsi => ۲ 


وا $-: 


تنفیذ الأوامر ls «cp —v /etc/hosts . «ls «rm hosts‏ 
النقطة period‏ ( . ( هي وسیلة سهلة الاستخدام لابشارة إلى الدليل الحالي .current directory‏ ويمكن 
استخدامها مع جميع أوامر لينكس» ولیس فقط مع الأمر 60. 


٤ الخطوة‎ ٤5٤ 


آدخل الأوامر التالية للنسخ copy‏ من الدليل المصدر source directory‏ مع الحفاظ على سمات الملف file‏ 
65 باستخدام الخیار م-: 

rm hosts 

ls 

cd /etc 

ls - hosts 

cp - hosts /home/sysadmin 

cd 


ls - hosts 


٢٢۲ 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


اساسيات لينكس 


:^$ rm hosts 


وا $-: 


Bc) CO تاه‎ 


$ وا‎ -l hosts 


= == == 1 zoot roor 150 Jam 22 15:13 8ں‎ 


$ cp -p hosts /home/sysadmin 


5 «eol 


:~$ وا‎ -l hosts 


=m- EES 1 sysadmin 275217 L50 Jam 22 15878 NOSTE 


:~$ 


ls «cd «cp —p hosts /home/sysadmin «ls -L hosts «cd /etc «ls «rm hosts تنفیذ الأوامر‎ 


-| hosts 


لاحظ أن التاریخ permission. c5 5! date‏ تم الحفاظ علیها كما هي. ملاحظة اخری هي أن الطابع 


الزمني timestamp‏ في التنفيذ أعلاه هو نفسه لکل من الأصل original‏ والنسخة (۱۲ دیسمبر (VE‏ 


٥‏ الخطوة ه 


اكتب الأوامر التالية للنسخ باستخدام اسماء اهداف مختلفة :different target name‏ 


3 


rm hosts 


cp -p /etc/hosts - 


cp hosts newname 


hosts newname‏ |- کا 


rm hosts newname 


س0 اساسيات لينكس 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


:-$ cp -p /etc/hosts - 


:~$ cp hosts newname 


:~$ وا‎ -l hosts newname 


8ج 18818 22 sysadmin SVE 1.50 Jem‏ 1 حدورحد تم ورت 
-rw-r--r-- 1 sysadmin sysadmin 150 Jan 22 16:29 newname‏ 
rm hosts newname‏ و ه: 


:~$ 


ls —l hosts newnam «cp hosts newname «cp -p /etc/hosts ~ «rm hosts تنفيذ الأوامر‎ 


rm hosts newname ٥ 


النسخة الأولى من الخیار 0- حافظت على الطابع الزمني الأصلي original timestamp‏ تذكر أن علامة 


تيلدا 1106 ( - ) تمثل الدليل الرئيسي Jhome/sysadmin‏ 


النسخه الثانية حددت اسم ملف مختلف ۲٧۴‏ کهدف target‏ وذلك لعدم استخدام الخیار ep‏ النظام 
استخدم التاريخ والوقت الحالي للهدف target‏ وبالتالي فإنه لم يتم الحفاظ على الطابع الزمني الأصلي والموجود 


في الملف المصدر Jetc/hosts‏ 


وأخيراء لاحظ أنه يمكنك إزالة remove‏ أكثر من ملف في وقت واحد كما هو مبين مع الأمر "۲ الأخير» 


حيث تم إزالة ملفين بنفس السطر. 


٦ الخطوة‎ 7 


استخدام الخيار -R‏ لنسخ جميع الملفات في الدليل. لهذه المهمة سوف ننسخ الدليل /ete/Udev‏ ونعرض محتويات 


:copied directory الدلیل المنسوخ‎ 


iye 


AN‏ اساسيات لينكس 


mkdir Myetc 
cp —R /etc/udev Myetc 
ls - Myetc 


ls ظا-‎ Myetc 
التنفيذ ينبغي أن يكون مشابه لما يلي:‎ 


sysadminGlocalhost:-«$ mkdir 6 
sysadminGlocalhost:-$ cp -R /etc/udev Myetc 
sysadminGlocalhost:^$ ls -l Myetc 

total 0 

drwxr-xr-x 1 sysadmin sysadmin 32 Jan 22 16:35 udev 
sysadminGlocalhost:-$ ls -IR Myetc 

62 

total 0 


drwxr-xr-x 1l sysadmin sysadmin 32 Jan 22 16:35 udev 


Myetc/udev: 


total 4 


drwxr-xr-x 1 sysadmin sysadmin 56 Jan 22 16:35 rules.d 


EES JL 53793907170 9۷52727 218 Jam 22 15535 1618657 COME 


Myetc/udev/rules.d: 
total 8 


EES 1 sysacmim sysacmim 306 Jem 22 LOIS 
70-persistent-cd.rules 


-rw-r--r-- 1 sysadmin sysadmin 1157 Jan 22 16:35 7 


sysadminGlocalhost: ^$ 


ls -IR Myetc «ls - Myetc «cp -R /etc/udev Myetc «mkdir Myetc تنفیذ الأوامر‎ 


۱۳۵ 


AR‏ اساسیات لینکس 


V الخطوة‎ ٧ 
im دليل ما مع الأمر‎ remove استخدم الخیار ۲ - لإزالة‎ 
5 


rm -r 6 


5 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


:-$ rm -r 160 


وا $-: 


ls ء‎ rm -r Myetc » ls تنفیذ الأوامر‎ 


لاحظ أن الأمر rmdir‏ يمكن أن يستخدم Lad‏ لحذف الدلائل «delete directories‏ ولكن فقط إذا كان الدلیل 


فارغ empty‏ اي انه لا يحتوي على أية ملفات. 


نلاحظ آیضا ان الخیار ۲ - يزيل الدلائل directories.‏ ومحتویاتها contents‏ بشکل متکرر. 


۸ الخطوة ^ 


ان Adae‏ نقل ملف مشابهة لعمليتي القص واللصق cut and paste‏ القص یکون للملف من الموقع الأصلي 
original location‏ ثم اللصق إلى الوجهة المحددة specified destination‏ نقل ملف من الدلیل المحلي 


local directory‏ یتم من خلال تنفيذ الأوامر التالية: 


۱۳۹ 


امر لینکس الوصف 

touch premove‏ | يقوم هذا الأمر بتحديث الملف premove‏ فان لم ass‏ أي ملف بذلك 
الاسم» فانه یقوم بانشاء ملف فارغ بنفس الاسم 0۲6۲۲۱0۷6 
mv premove ©‏ | هذا الأمر بقص الملف premove‏ ثم لصقه إلى ملف اخر والمسمی 
06 


postmove ازالة الملف‎ | rm 6 


التنفیذ ينبغي أن يكون مشابه لما يلي: 


z 3 
My 
اساسیات ليذ‎ ET S 
2:30 لینکس‎ cu : m 4 
touch premove 
ls 
mv premove postmove 
ls 
rm postmove 


A‏ اساسیات لینکس 


$ touch premove 


وا 5 


$ mv premove postmove 


$ ls 


postmove 


rm postmove «ls «mv premove postmove «ls «touch premove تنفیذ الأوامر‎ 


۱۳۸ 


و 
Me‏ هروه 
AW‏ اساسیات لینکس 2-030 
سس iA‏ 


المعمل السابع — الأرشفة والضغط 


Archiving and Compression 


و اساسیات لینکس 2230 
۷۱ مقدمة 


هذا هو المعمل السابع: آرشفة وضغط الملفات ثم فك الارشفة والضغط. عن طريق أداء هذا التمرین» سوف تتعلم 


كيفية التعامل مع ملفات الأرشیف. 


o‏ انشاء ملفات الأرشيف باستخدام الأمر tar‏ مع الضغط وبدونه. 
o‏ ضغط وفك ضغط الملفات مع الأمر .gzip‏ 
o‏ ضغط وفك ضغط الملفات مع الأمر .BZIP2‏ 


o‏ استخدام الأمرين 210 و unzip‏ لضغط الملفات ثم فك الضغط. 
۲ أوامر الأرشفة 


في هذه المهمة» سوف نستخدم الأوامر gzip‏ و 02102 و 210/0210 بغرض أرشفة archive‏ واستعادة 
الملفات [restore files‏ وقد صممت هذه الأوامر لوظيفتين رئيسيتين؛ الأولى دمج ملفات متعددة merge‏ 
multiple files‏ في ملف واحده اما الوظيفة الثانية فهي ضغط compress‏ الملفات الكبيرة إلى ملفات أصغر. 
وفي بعض الحالات سوف تؤدي الوظيفتين معاً. 


أرشفة البيانات مهمة لعدة أسباب منها: 


4 صعوبة نقل transfer‏ الملفات الكبيرة» فجعل حجم هذه الملفات أصغر يساعد في تسريع عملية النقل. 

s%‏ نقل ملفات متعددة multiple files‏ من نظام إلى آخر يصبح مزعجاً عندما يكون هناك العديد من 
الملفات. فعملية دمجها في ملف واحد للنقل transport‏ يجعل هذه العملية أسهل. 

٭ الملفات يمكن أن تحتل وبسرعة مساحة Space‏ كبيرة das‏ خاصة على الوسائط الصغيرة القابلة 
للإزالة removable media‏ مثل محركات أقراص الإبهام thumb drives‏ لذلك فان عملية 


الأرشفة Archiving‏ تقلل reduces‏ من هذه المشكلة. 


lí. 


[ji 


archiving commands‏ المختلفة؟ الجواب هو أن هذه الأوامر لها مميزات features‏ مختلفة عن بعضها 
البعضء على سبيل المثال؛ بعض من أوامر الأرشفة تسمح لك بحماية protect‏ ملف الأرشيف archive file‏ 
عن طريق کتابة کلمة سر Lal password‏ هناك اختلاف في تقنيات الضغط compression‏ 


56 المستخدمة. 
المهم أن تتعرف على وظيفة function‏ کل منهاء ومع مرور الوقت سوف تتعلم اختيار أداة الأرشفة archive‏ 


tool‏ الصحيحة للحالات التي قد تواجهك. 


M‏ ری 


استخدم الأمر tar‏ لانشاء أرشيف في الدليل /etc/udev‏ احفظ نسخة احتياطية backup‏ في الدليل 
:~/mybackups‏ 

cd 

mkdir mybackups 

tar —cvf mybackups/udev.tar /etc/udev 


ls mybackups 


S 
jfy " ٧0 | Ep ji 
2/530 ساسیات ابتکني‎ IM 
لینکس وهي لماذا يوجد الكثير من أوامر الأرشفة‎ QUAS نقطة واحدة قد تكون مربكة للمستخدمين الجدد‎ 
التنفيذ ينبغي أن يكون مشابه لما يلي:‎ 


اساسیات لینکس 


:~$ cd 

: وه‎ mkdir mybackups 

:-$ tar -cvf mybackups/udev.tar /etc/udev 
tar: Removing leading ^/' from member names 
/etc/udev/ 


/etc/udev/rules.d/ 


/etc/udev/rules.d/70-persistent-cd.rules 


/etc/udev/rules.d/README 
/etc/udev/udev.conf 


:~$ ls mybackups/ 


تنفیذ myb «tar —cvf mybackups/udev.tar /etc/udev «mkdir mybackups «cd »4 sy!‏ کا 


«ackups 


تم استخدام الأمر tar‏ لدمج الملفات المتعددة merge multiple files‏ في ملف واحد. لاحظ ان الأمر السابق 


لا يقوم بعملية ضغط compress‏ للبیانات data‏ بل أرشفتها فقط. 


الخیار -c‏ يُستخدم مع الأمر tar‏ لانشاء ملف الارشفة „tar file‏ بينما الخيار -v‏ فهو verbose"‏ " حيث يقوم 


بإظهار الحدث. بينما يتم استخدام الخیار ‏ - لتحديد اسم ملف .tar file‏ 


لمعلوماتك: tar‏ يرمز لأرشيف الشريط Tape ARchive‏ وقد استخدم هذا الأمر أصلا لانشاء نسخ احتياطية 


للأشرطة «tape backups‏ ولكن اليوم یتم استخدامه لإنشاء ملفات الأرشيف archive files‏ 


ليس هناك حاجة لاستخدام الملحق tar. ) extension‏ ) لأرشفة اسم ملف archive file name‏ » ومع 
ذلك فإنه يساعد على تحديد نوع الملف file type‏ حيث يعتبر اسلوب جيد وذلك عند إرسال ملف الأرشيف 


archive file‏ إلى شخص آخر. 


اساسیات لینکس 


Y الخطوة‎ V, Y,Y 


اعرض محتويات ملف tar‏ الذي سبق وقمت بانشاته سابقاء لاحظ معاني الخيارات التالية والمصاحبة للأمر tar‏ 


list contents لعرض قائمة المحتویات‎ : 1 e 
verbose لاظهار الحدث‎ : ۷ e 


filename :لتحدید اسم الملف‎ f ٠ 


tar —tvf mybackups/udev.tar 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


:~$ tar -tvf mybackups/udev.tar 
drwxr-xr-x root/root 0 2015-01-28 16:32 etc/udev/ 
drwxr-xr-x root/root 0 2015-01-28 16:32 etc/udev/rules.d/ 


-rw-r--r-- root/root 306 2015-01-28 16:32 


etc/udev/rules.d/70-persistent-cd.rules 


-rw-r--r-- root/root 1157 2012-04-05 19:18 etc/udev/rules.d/README 


-rw-r--r-- root/root 218 2012-04-05 19:18 etc/udev/udev.conf 


۶$ 


tar -tvf mybackups/udev.tar تنفیذ الأمر‎ 


لاحظ أن الملفات تم نسخها احتياطيا backed up‏ بشکل متكرر recursively‏ وذلك باستخدام المسار النسبي 
relative path names‏ وهو مهم جدا عند استخراج extract‏ تلك الملفات. لأنه سيتم وضعها في دليلك 


.current files الملفات الحالية‎ override ولیس فوق‎ «your current directory الحالي‎ 


نن ۳٣‏ و 


لأنشاء ملف tar‏ مضغوط استخدم الخیار 2 - مع الامر السابق: 


Nw 
اساسیات لینکس‎ AN 


tar -20۷۱ mybackups/udev.tar.gz /etc/udev 


ls طاح‎ mybackups 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


sysadminGlocalhost:-$ tar -zcvf mybackups/udev.tar.gz ۵۲ 
tar: Removing leading `/' from member names 

/etc/udev/ 

/etc/udev/rules .d/ 

/etc/udev/rules.d/70-persistent-cd.rules 
/etc/udev/rules.d/README 


/etc/udev/udev.conf 


sysadminGlocalhost:^$ ls -lh mybackups/ 


total 16K 
-rw-rw-r-- 1 sysadmin sysadmin 10K Jan 25 04:00 
-rw-rw-r-- 1 sysadmin sysadmin 1.2K Jan 25 04:34 


sysadminGlocalhost: ^$ 


ls طاح‎ mybackups «tar —zcvf mybackups/udev.tar.gz /etc/udev تنفيذ الأمرين‎ 


لاحظ الفرق في الحجم؛ حيث ان النسخة الاحتياطية backup‏ الأولى ٠١‏ کیلوبایت وبالتالي أكبر من النسخة 


الاحتياطية backup‏ الثانية وهي ۱,۲ كيلوبايت فقط. 


الخیار -z‏ يستفيد من مجموعة الأمر gzip utility‏ وذلك للقیام بعمل الضغط. 


٤ الخطوة‎ ۷٤ 


قم باستخراج Extract‏ محتویات الأرشيف archive contents‏ لاحظ ان البيانات data‏ يعاد حفظها 


0 في الدلیل الحالي current directory‏ بشکل افتراضي: 


ít 


S‏ اساسیات لینکس 


cd mybackups 

ls 

tar —xvf udev.tar.gz 
ls etc 

etc/udev‏ کا 


ls etc/udev/rules.d 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


sysadminGlocalhost:-$ cd mybackups 


sysadminlocalhost:-/mybackups$ ls 


sysadminGlocalhost:-/mybackups$ tar -xvf udev.tar.gz 
etc/udev/ 

etc/udev/rules.d/ 
etc/udev/rules.d/70-persistent-cd. 
etc/udev/rules.d/README 

etc/udev/udev.conf 
sysadminlocalhost:-/mybackups$ ls 

etc 

sysadminlocalhost:-/mybackups$ ls 

udev 

sysadminGlocalhost:-/mybackups$ ls etc/udev 


rules.d  udev.conf 


sysadminGlocalhost:-/mybackups$ ls etc/udev/rules.d 


70-persistent-cd.rules README 


sysadminélocalhost:-/mybackups$ 


تنفیذ الأوامر etc/ude «ls etc/udev «ls etc «ls «tar —xvf udev.tar.gz «cd mybackups‏ کا 


v/rules.d 


£o 


اساسیات لینکس 


إذا آردت ان تعيد الملفات إلى موقعها الأصلي coriginal location‏ فيجب أولا کتابة الأمر 60 إلى الدليل / 
ثم تشغيل الأمر «ar‏ في هذا المثال سيُطلب منك أن تكون مسجلاً logged in‏ کمسؤول للنظام» لإنشاء ملفات 


.administrator لا يتم إلا عن طريق مسؤول النظام‎ /etc directory في الدلیل‎ creating files 


٥‏ الخطوة ه 


لاضافة ملف إلى أرشيف موجود استخدم الخيار ٣‏ - أمر tar‏ اكتب الأوامر التالية لتنفیذ هذا الإجراء والتحقة 
۱ إلى أرشيف موجو م الخيار ۲ - مع أمر وامر التالية لتنفی (جراء و 


من وجود ملف جدید في أرشيف "tar‏ 


tar -rvf udev.tar ۳6 


tar —tvf udev.tar 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


5 tar -rvf udev.tar /etc/hosts 
tar: Removing leading `/' from member names 
/etc/hosts 

$ tar -tvf udev.tar 
drwxr-xr-x root/root 0 2015-01-28 16:32 etc/udev/ 
drw r ج۳‎ 0 2015-01-28 16:32 etc/udev/rules.d/ 


-rw-r--r-- root/root 306 2015-01-28 16:32 


etc/udev/rules.d/70-persistent-cd.rules 


-rw-r--r-- root/root 1157 2012-04-05 19:18 etc/udev/rules.d/README 
-rw-r--r-- root/root 218 2012-04-05 19:18 etc/udev/udev.conf 


-rw-r--r-- root/root 172 2017-08-21 23:28 etc/hosts 


$ 


tar —tvf udev.tar «tar -rvf udev.tar /etc/hosts تنفیذ الأمران‎ 


اساسیات لینکس 


٦ الخطوة‎ ٦ 


في الأمثلة التالیة سوف نستخدم امري 0210 و gunzip‏ لضغط compress‏ وفك الضغط uncompress‏ 
عن ملف. نفذ الأوامر التالية لضغط نسخة من الملف :WOrds‏ 

cp /usr/share/dict/words . 

ls - words 

gzip words 


ls -l words.gz 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


$ cp /usr/share/dict/words ۰ 
$ ls -l words 
-rw-r--r-- 1 sysadmin sysadmin 938848 Jan 25 07:39 words 


$ gzip words 


$ ls -l words.gz 


Jam 25 078959‏ 255996 21727017 همع هروه 1 من )ورت 
$ 


ts -l words.gz «gzip words «ls -L words «cp /usr/share/dict/words . »4 تنفیذ الأو‎ 


لاحظ أن حجم size‏ الملف المضغوط zipped file‏ يساوي ۲٥٥۹۹٢‏ بايت في المثال أعلاه وهو أصغر بكثير 
من الملف الأصلي AY AAEA‏ 
هام جدا: عند استخدام gzip‏ یتم استبدال الملف الأصلي بواسطة ملف مضغوط. في المثال أعلاه» تم استبدال 


.Words.gz بالملف‎ words الملف‎ 


اساسیات لینکس 


مھم جدا: عندما تقوم بفك ضغط الملف 0 سیتم استبدال الملف المضغوط zipped file‏ مع الملف 


.original file الأصلي‎ 


۷ الخطوة‎ V, ۷ 


نفذ الأوامر التالية لفك ضغط الملف :WOrds.gz‏ 


-L words.gz‏ کا 
gunzip words.gz‏ 


ls - words 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


5 ls -l words.gz 


E EOE 1 sysadmin SVE 2559965 Jam 25 07839 
$ gunzip words.gz 
$ ls -l words 

l sysadmin SSAC 232949 Jan 29 (078.99) 658‏ و2 
$ 


ls -L words «gunzip words.gz «ls -L words.gz تنفيذ الأوامر‎ 


لینکس يوفر عددا كبيرا من مرافق الضغط compression utilities‏ بالاضافة إلى .gzip/gunzip‏ کل منهم 
له إيجابياته وسلبياته pros and cons‏ مثلاً ضغط أسرع faster compression‏ ومعدلات ضغط أفضل 
better compression rates‏ وأكثر مرونة more flexible‏ وقابلة للحمل more portable‏ وأسرع 


بفك الضغط .decompression‏ 


A‏ اساسیات لینکس 


الأمران gzip/gunzip‏ تحظی بشعبية كبيرة في لينكس. بينما الأمران BZIP2/ bunzip2‏ لهما شعبیتها 
الكبيرة ايضاً ولكن بعض توزیعات لینکس» ومن حسن الحظ أن معظم وظائفھا كطريقة تشغیل run‏ الأوامر هي 


نفس الأمران السابقان .gzip/gunzip‏ 
۸ الخطوة ۸ 


ان استخدام تقنية BZIP2‏ و 0۱۳۱2102 لضغط compress‏ وفك الضغط uncompress‏ يشبه استخدام 

gunzips 0‏ حيث يتم إنشاء ملف مضغوط مع وصلة «extension .Dz2‏ ثم نتم إزالة الوصلة 
extension‏ عند فك الضغط. نفذ الأوامر التالية لضغط نسخة من ملف ۸۷0۲[8: 

ls - words 

bzip2 words 


ls -l words.bz2 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


5 وا‎ -l words 


-rw-r--r-- 1 sysadmin sysadmin 938848 Jan 25 07:39 words 


$ bzip2 words 


$ ls -l words.bz2 


greek 172-017 355405 Jam 25 07859‏ 1 تت 
$ 


ls -L words.bz2 ۰۵02102 words «ls -l words »« 5! تنفيذ‎ 


إذا قارنت حجم ملف 022. الناتج 335405 مع حجم ملف .gz‏ 255996 الناتج من الخطوة رقم ۰۷ ستلاحظ 


أن gzip‏ قام بعمل أفضل عند ضغط هذا الملف. 


A‏ اساسیات لینکس 


۹ الخطوة ۹ 
نفذ الأوامر التالیة لفك ضغط uncompress‏ الملف :words.bz2‏ 
ls -|1 2‏ 


bunzip2 words.bz 


ls - words 
التنفيذ ينبغي أن يكون مشابه لما يلي:‎ 


$ ls - 2 


Jan 25 9‏ 3539409 ۷629 2هو 1 سه نم ورت 


5 bunzip2 words.bz2 


$ ls -l words 


Jam 25 (078959 85‏ ۹32949 25227 27996070 1 حدم حدم د ورد 


تنفیذ الأوامر -L words «bunzip2 words.bz2 «ls -lL words.bz2‏ کا 
تعتبر ملفات الأرشفة 0210 و 6210 هي الاکثر شیوعا في عالم لينكس» لکن یتم استخدام نوع أرشفة مختلف 
في أنظمة التشغيل الأخرى مثل ویندوز. ولقد تم دعم support‏ تطبيق ويندوز اکسبلورر Windows‏ 


۲ لیتمکن من استخراج ملفات الأرشيف zip archive files‏ 


لذلكء إذا كنت تخطط لمشاركة ارشیف archive‏ مع مستخدمي ویندوزء یفضل استخدام 210. وعلی خلاف 
0 و 02102 ۰ فان الأمر zip‏ عند ضغط ملف ما فإنه يقوم بعمل نسخة من الملف الأصلي original file‏ 


وهي التي یتم ضغطها؛ اما الأصل فيبقى كما هو وبدون أي ضغط. 


رر اک ۱ 


استخدم الأمر zip‏ لضغط ملف :WOrds‏ 


EM 
اساسيات لينكس‎ ES 


zip words.zip words 


ls -l words.zip 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


$ zip words.zip words 
adding: words (deflated 73$) 


$ ls -l words.zip 


EVEN 2561.32 Jew 25 21825‏ همع ری 1 نت )ورت 


$ 


تنفيذ الأمرين -L words.zip «zip words.zip words‏ کا 
في المثال أعلاه الجزء words.zip‏ من الأمر zip‏ يعني اسم الملف الذي ترغب في انشانه. اما الملف words‏ 


فھو الذي ترید وضعه في ملف مضغوط. 


مهم: Y‏ حاجة لاستخدام zip extension‏ مع اسم ملف مضغوط. ومع ذلك فانه من مفيد لتحديد نوع الملف. 


وهو یعتبر أيضا اسلوب جيد عند ارسال ملف الأرشیف إلى شخص آخر. 


BELTS LAM 


zip ومحتویاته مع الأمر‎ /etc/udev اضغط الدلیل‎ 
zip -r udev.zip ۷ 


-Ludev.zip‏ کا 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


اساسیات لینکس 


$ zip -r udev.zip ٧ 
adding: etc/udev/ (stored 05( 
adding: etc/udev/rules.d/ (stored 0%) 


adding: etc/udev/rules.d/70-persistent-cd.rules (deflated 292) 


adding: etc/udev/rules.d/README (deflated 50%) 


adding: etc/udev/udev.conf (deflated 24%) 
$ ls -l udev.zip 


-rw-rw-r-- 1l sysadmin sysadmin 1840 Jan 25 21:33 
$ 


ls -Ludev.zip «zip -r udev.zip /etc/udev تنفيذ الأمرين‎ 


الأمر descends Os tar‏ تلقائیا خلال الدلائل الفرعية للدلیل المحدد ليتم ارشفتهاء كما هو الحال في المثال 
السابق 610/06۷ بينما عند التعامل مع الأوامر 82122 و621۳ zip s‏ يجب تحديد الخیار -r‏ من أجل 


التحرك recursion‏ إلى الدلائل jl‏ عیة .subdirectories‏ 


3ط >1 


لعرض محتويات ملف مضغوط «zip‏ استخدام الخیار -l‏ مع الأمر :unzip‏ 


unzip - udev.zip 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


٢ 


اساسیات لینکس 


$ unzip -l udev.zip 


Archive:  udev.zip 


2015-01-28 16: etc/udev/ 


2015-01-28 16: etc/udev/rules .d/ 


2015-01-28 16: etc/udev/rules.d/70-persistent-cd.rules 


2012-04-05 19: etc/udev/rules.d/README 


2012-04-05 19: etc/udev/udev.conf 


5 files 


$ 


unzip -l udev.zip تنفیذ الأوامر‎ 


Fs 


لاستخراج أرشيف ملف من نوع «zip.‏ استخدم الأمر unzip‏ دون أي خيارات options‏ في هذا المثال نحن 


بحاجة أو لا لحذف الملفات tar‏ التي تم إنشاؤها في المثال السابق: 


rm -r etc 


unzip udev.zip 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


اساسیات لینکس 


5 gu =F GG 
5 unzip udev.zip 
Archive:  udev.zip 
creating: etc/udev/ 


creating: etc/udev/rules.d/ 


inflating: etc/udev/rules.d/70-persistent-cd.rules 


inflating: etc/udev/rules.d/README 
inflating: etc/udev/udev.conf 


$ 


unzip udev.zip «rm -r etc تنفيذ الأمرين‎ 


of 
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المعمل الثامن - القنوات القياسية والأنابیب وإعادة 

التوجیه 

Pipes, Redirection and REGEX 
| 
| 
| 


2230 اساسیات لینکس‎ ES 
مقدمة‎ ۱ 


هذا هو المعمل الثامن: القنوات القياسية و الأنابیب وإعادة التوجیه. عن طريق آداء هذا التمرين» سوف نتعلم كيفية 


اعادة توجیه تبارات e pali‏ و استخدام التعابیر catal‏ واستخدام آوامر الملقات لتصفية النص, 
ه تعلم كيفية إعادة توجیه القنوات القياسية (المدخلات والمخرجات والاخطاء). 


ه استخدام التعابیر العادية لتصفية مخرجات الأوامر أو محتویات الملفات. 


e‏ عرض الملفات الکبيرة كاملة أو استخدام آوامر الترحیل لعرض آجزاء مختارة منها. 
۲ قنوات سطر الأوامر واعادة التوجیه 


عادة عند تنفيذ الأوامر یتم عرض الناتج في نافذة .terminal‏ وهذا الناتج output‏ (وأیضا يسمى قناة 
(channel‏ 305( عليه التنفیذ القياسي «Standard output‏ ویشار اليه بالرمز (stdout)‏ اما القناة المعبرة 
عنه فهي القناة رقم 2 

الخطأ القياسي Standard error (stderr)‏ ویظهر عند حدوث أي خطأ آثناء تنفیذ الأوامر. اما القناة المعبرة 


عنه فهي القناة رقم ۲ ء وبشکل افتراضي یتم اخراج رسائل الخطأ بواسطتها إلى نافذة terminal‏ 


واخیراً الادخال القياسي Standard input (stdin)‏ وهو عادة ما نقوم بادخاله من آوامر عن طریق الكتابة 
على لوحة المفاتيح» اما القناة المعبرة عنه فهي القناة رقم .٠‏ ومع ذلك ومن خلال اعادة توجیه redirecting‏ 


الإدخال القياسي Standard input‏ الملفات يمكن أن تستخدم Lad‏ ک .Stdin‏ 


في هذا التمرين سوف نستخدم الأحرف characters‏ التي تعيد توجيه redirect.‏ المخرجات output‏ من 
التنفيذ القياسي standard output (stdout)‏ والخطأ القياسي standard error (stderr)‏ إلى ملف أو 


آمر آخر بدلا من نافذة terminal‏ 


اساسیات لینکس 


١ الخطوة‎ 1۱ 


يُستخدم رمز إعادة التوجيه redirect‏ < لإعادة توجيه التنفيذ output‏ من الناتج الافتراضي stdout‏ لنافذة 


۱ الی ملف. اكتب ما يلي لتحقيق ذلك: 
6 دح echo "Hello World"echo "Hello World"‏ 
cat mymessage‏ 
التنفيذ ينبغي أن يكون مشابه لما يلي: 


:~$ echo "Hello World" 


Hello World 


:~$ echo "Hello World" > mymessage 


:~$ cat mymessage 


Hello World 


cat my «echo "Hello World" > mymessage ٠ echo "Hello World" تنفیذ الأوامر الثلاثة‎ 


message 


stdout یقوم بإخراج الجملة السابقة على الاخراج القياسي‎ echo "Hello World" الأمر الأول وهو‎ e 
„terminal لتظهر في النافذة الطرفية‎ 

e‏ اما الأمر الثاني echo "Hello World" > mymessage‏ فهو يعيد توجيه التنفيذ؛ Ya‏ من 
إرساله إلى «terminal‏ يتم إرسال التنفيذ إلى ملف يسمى .mymessage‏ 


.mymessage محتويات ملف‎ cat وأخيراً يعرض الأمر‎ e 


اساسیات لینکس 


۲ الخطوة Y‏ 
عند استخدام رمز < لاعادة توجیه stdout‏ فان محتویات الملف السابقة تتم ازالتھاء اکتب الأوامر التالية لمشاهدة 
عرض توضيحي: 
cat 6‏ 
echo Greetings < 6‏ 


621 6 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


$ cat 6 


Hello World 


:~$ echo Greetings > mymessage 


:~$ cat mymessage 


Greetings 


cat m «echo "How are you?" << mymessage «cat mymessage تنفيذ الأوامر الثلائة‎ 


ymessage 
استخدامنا رمز إعادة توجیه واحد " < " للكتابة فوق ملف موجود. وهذا ما یسمی باتلاف ملف‎ Uil لاحظ‎ 


.clobbering 


Y الخطوة‎ A, V, Y 


يمكنك تجنب اتلاف ملف clobbering‏ باستخدام رمزي " << " بدلا من " < ". فباستخدام رمزي إعادة التوجیه 
يتم الحاق append‏ البیانات الجديدة إلى الملف دون ازالة أو اتلاف للمحتویات السابقة. نفذ الأوامر التالية 
لمشاهدة عرض توضيحي لهدا: 


۱5۸ 


اساسیات لینکس 


621 6 
echo "How are you?" << 6 


cat mymessage 


التنفيذ ينبغي أن يكون مشابه لما يلي: 


$ cat 6 
Greetings 


$ echo "How are you?" << mymessage 


$ cat mymessage 


Greetings 


How are you? 


cat m ۰ echo "How are you?" << mymessage «cat mymessage تنفيذ الأوامر الثلاثئة‎ 


ymessage 


لاحظ أنه باستخدام " << " يتم الاحتفاظ بكافة البیانات الموجودة ويتم إلحاق البیانات الجديدة في نهاية الملف. 


٤ الخطوة‎ ٤ 


یستخدم الأمر find‏ للبحث في ملفات النظام filesystem‏ عن ملف ما استنادا إلى أحد المعايير di criteria‏ 


اسم الملف filename‏ وسنستخدمه الان لاظهار كيفية عمل «stderr‏ قم بتشغيل الأمر التالي ولاحظ التنفيذ: 


find /etc -name hosts 


التنفيذ ينبغي أن یکون مشابه لما يلي: 


۱5۹ 


اساسیات لینکس 


:^$ find /etc -name hosts 


find: ^/etc/ssl/private': Permission denied 


"۸ٗ +0 9 


find /etc -name hosts الأمر‎ xài 


لاحظ رسالة ji error message Usill‏ إلى abi‏ لا تمتلك الصلاحية permission‏ للاخول 
access‏ لملف أو دليل ما. وذلك لأن المستخدم العادي regular user‏ ليس 433 الحق في النظر dah‏ 


بعض الدلائل. ویتم إرسال هذه الأنواع من رسائل الخطأ إلى ۰51067۲ ولیس إلى .Stdout‏ 


ستتم تغطية أمر البحث find‏ بمزيد من التفاصيل في وقت لاحق. الآن نستخدمه فقط لإظهار الفرق بين الاخراج 


القياسي stdout‏ والخطأ القياسي „stderr‏ 
٥‏ الخطوة ه 
لإعادة توجيه stderr‏ (رسائل الخطأ) إلى ملف ماء نفذ الأمر التالي: 
find /etc -name hosts 2< 6‏ 


cat err.txt 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


ES find /etc -name hosts 2» err.txt 
/etc/hosts 


2S car CEE EXE 


find: ^/etc/ssl/private': Permission denied 


وم : 


cat err.txt «find /etc -name hosts 2< err.txt تنفیذ الأمرين‎ 


اساسیات لینکس 


تذکر أن القناة الواصفة file descriptor‏ لرسائل الخطأ stderr‏ هي القناة رقم ٢ء‏ لذلك یتم استخدامها جنبا 
إلى جنب مع رمز " < " لاعادة توجیه redirect.‏ تنفیذ 9016۲۲ إلى ملف یسمی 6۲۲.0 . لاحظ أن الرمز 


" »1 " هو نفسه" "> E‏ 


ملاحظة: يوضح المثال السابق لماذا فهم عملية إعادة التوجيه مهمة جداً. فعلى سبیل المثال؛ إذا كنت cab ji‏ 
بتجاهل الأخطاء errors‏ التي يعرضها الأمر find‏ حالياً فيمكنك إعادة توجيه redirect‏ تلك الرسائل 
5 في ملف ما والنظر إليها في وقت لاحق» مما يجعل من الأسهل أن تركز على ما تبقى من إخراج 


E^ 


٦ الخطوة‎ ٦ 


يمكنك أيضا إعادة توجيه الإخراج القياسي 5100101 و رسائل الخطأ stderr‏ إلى ملفين منفصلین: 


find /etc -name hosts > 510.001 2< ۲ 
cat std.err 


cat std.out 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Beds) iine ای‎ -name hosts > ste 911-22 sra err 


2S cat std.err 


find: ^/etc/ssl/private': Permission denied 


:^$ cat std.out 


/etc/hosts 


cat std.out «cat std.err «find /etc -name hosts > std.out 2» 510.67۳ الأوامر‎ xài 


اساسیات لینکس 


لاحظ أن المسافة مسموحة ولكنها ليست مطلوبة بعد رمز اعادة التوجیه " < ". 


V الخطوة‎ ۸,۲۷ 


لإعادة توجیه redirect‏ کل من الاخراج القياسي standard output (stdout)‏ وايضاً رسائل الخطأ 
standard error (stderr)‏ إلى ملف واحدء قم أولاً باعادة توجیه stdout‏ إلى ملف ثم بعدها اعد توجيه 


۲ إلى نفس الملف باستخدام 2<81. 


find /etc -name hosts »find.out 1 


cat find.out 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


525 find /etc -name hosts < find.out 2»&1 


2S cat find.out 


find: ^/etc/ssl/private': Permission denied 


/etc/hosts 


cat find.out « find /etc -name hosts »find.out 2-81 الأمرين‎ xai 


2-81 هي جزء من الأوامر وتعني إرسال stderr‏ رسائل الخطأ (القناة رقم 2 (channel‏ إلى ملف ثم 


ارسال الإخراج القياسي stdout‏ (القناة رقم 1 (channel‏ إلى نفس مكان السابق. 


۸ الخطوة ۸ 


الإدخال القياسي Standard input (stdin)‏ يمكن آیضا ان يتم اعادة توجیهه. عادة یتم ادخال stdin‏ من 


لوحة المفاتیح «Keyboard‏ ولكن في بعض الأحيان نريده أن يأتي من ملف بدلا من لوحة المفاتیح. على سبيل 


اساسیات لینکس 
المتال» الأمر tr‏ يحول الحروف من صغيرة إلى كبيرة وبالعكس» ویقبل البیانات من «stdin‏ ولكنه لا يقبل أبدا 
جعل ملف ما کمعطیات argument‏ . 
ملاحظة: اضغط على «D + Control‏ للاشارة إلى الأمر tr‏ وذلك لایقاف معالجة processing‏ الادخال 
القياسي :standard input‏ 

tr a-z A-Z 
this is interesting 


how 00 ۱ stop this? 


^D 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ tr a-z A-Z 


this is interesting 


HEALS LS 00857 
how CO لا‎ stop taig? 


BHON DO T SMOR 782 


:~$ 


^D «tr 2-2 A-Z تنفیذ الأمرين‎ 


ملاحظة: ^D‏ اختصار إلى .Control+d‏ 


8 الخطوة ۹ 


الأمر 1۳ يقبل مدخلات لوحة المفاتيح stdin‏ ثم يترجم translates.‏ الأحرف ويرسل التنفيذ إلى .Stdout‏ 


لإنشاء ملف ذو أحرف صغيرة؛ نفذ ما يلي: 


اساسیات لینکس 


tr A-Z a-z > myfile 
Wow | SEE NOW 


This WORKS! 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ tr A-Z a-z > myfile 


Wow. I SEE NOW 


This WORKS! 


tr A-Z 8-2 » myfile تنفیذ الأمر‎ 


اضغط على مفتاح Enter‏ للتأکد من ان المؤشر cursor‏ هو على الخط أدناه "This works!"‏ ثم استخدم 


4 لوقف الادخال. للتحقق من إنشاء الملف» نفذ الأمر التالي: 


cat myfile 


> CTRL < «d 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


89 cat myfile 


WOW. i See now 


this works! 


cat myfile تنفیذ الأمر‎ 


اساسیات لینکس 


E AE 


نفذ الأوامر التالية لاستخدام الأمر tr‏ عن طريق إعادة توجيه stdin‏ من ملف: 


cat myfile 


tr 3-2 A-Z > myfile 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ cat 6 
WOW. i See now 


this works! 


:~$ tr a-z A-Z > myfile 


WOW. I SEE NOW 


THIS WORKS! 


tr a-z A-Z > myfile «cat myfile تنفیذ الأمرين‎ 


۳ 7۹ A 1 


شكل مشهور آخر لعمليات إعادة التوجیه redirection‏ وهو اخذ تنفیذ output‏ امر ثم ارساله إلى أمر آخر 
کمدخل input‏ على سبيل المثال» مخرجات بعض الأوامر يمكن أن تكون las.‏ ضخمة massive‏ مما يؤدى 
إلى إخراج الناتج خارج الشاشة بسرعة كبيرة وبالتالي لا يستطيع المستخدم قراءته. نفذ الأمر التالي لأخذ تنفيذ 


الأمر ها وإرساله عبر الانبوب " | " إلى الأمر more‏ والذي یعرض صفحة واحدة من البيانات في کل مرة: 


ls -l /etc | more 


WS‏ اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


sysadminGlocalhost:-$ ls -l /etc | more 

tortal 372 

Jan 2015 adduser.conf‏ سیسات ور ورت 
Jan 2015 adjtime‏ وره وره )وور 
drwxr-xr-x Jan 2015 alternatives‏ 
امه 2191221112 2015 E Jan‏ ا تر Ole‏ 
drwxr-xr-x OCE 2014 apt‏ 


= = = = کک[‎ Apr 2012 bash.bashrc 


Gliewpsie E 72 Jan 2015 bash completion.d 


E WESTE SIS 342 Jan 2015 rme 

-rw-r--r-- 356 Apr 2012 bindresvport.blacklist 
-rw-r--r-- 321 Mar 2012 رر‎ CONE 

Irwxrwxrwx 15 Jun 18 2014 blkid.tab -» /dev/.blkid.tab 
drwxr-xr-x 1$ Jam 29 201059 8878617611810658 

- سب ووب ووس(‎ Jam 22 20157 683-89-27 ٤٨د‎ 621/28 Comi 
drwxr-xr-x Jan 29 2015 calendar 

drwxr-Xxr-x Jem 29 2017 6188108 

drwxr-xr-x Jan 29 2015 cron.daily 

drwxr-xr-x Jan 29 2015 cron.hourly 
drwxr-xr-x Jan 29 2015 cron.monthly 


Mell 15 2012 813616608 668‏ سن چ رس مد 2 


تنفیذ الأمر -L/etc | more‏ کا 
للخروج من هذه القائمة. 


الأمر ]رام مفيد لاستخراج الحقول fields‏ من الملفات التي اما أن تكون محددة delimited‏ بواسطة حرف 


Jia‏ النقطتين (:) في etc/passwd‏ أو أن يكون لها عرض ثابت fixed width‏ وهو يوفر قدرا كبيرا من 


١ 


| ْمممممممْن؟©ن؟ن؟؟ن؟بأآأمممممممممممممممممممممممممممممم يز 


ION 1 NM 

x mau DS 
2:2150 اساسیات لینکس‎ E وپ‎ 
المخرجات» وهو ما يظهر في الأمثلة المقبلقه لذلك سنقوم بعملية إعادة التوجیه لتلك المخرجات باستخدام‎ 
. character | 

۱۲ الخطوة‎ ٦ 

في المثال التالي» سوف تستخدم أمر ]رام لاستخراج آسماء المستخدمین الموجودين في قاعدة بيانات 
6 تسمی /etc/passwd‏ (ملف يحتوي على معلومات حساب المستخدم user account‏ 
(information‏ نفذ الأمر cut‏ فقط: 

cut -d: -f1 0‏ 
ويأتي في التنفیذ ادناه جزء فقط من (خراج الأمر icut‏ 
ET‏ | 


ہے فد د 
AS‏ اساسيات لينكس 


sysadminGlocalhost:-«$ cut -d: -f1 /etc/passwd 


root 


daemon 


mail 
news 
uucp 
proxy 
www-data 
backup 
list 
abe 
gnats 
nobody 
libuuid 
syslog 
bind 
sshd 


operator 


cut -d: -11 /etc/passwd تنفیذ الأمر‎ 


۱۳ so bet ۷۷۴ 


مخرجات output‏ الأمر السابق لا يتم عرضها بالكامل في الشاشة. سنقوم في الخطوة التالية بأخذ مخرجات 


الأمر ]رام واعادة توجیهها إلى الأمر ]890۲ء كما في المثال التالي: 


cut -d: -f1 /etc/passwd | sort 


^N‏ اساسيات لينكس 


ويأتي في الشاشة ادناه جزء فقط من التنفیذ : 


sysadminGlocalhost:-«$ cut -d: -f1 /etc/passwd | sort 


backup 
bin 
bind 
daemon 
games 
gnats 
086 
libuuid 


ESE 


news 
nobody 
operator 
proxy 
root 
sshd 
Sync 


Sys 


cut -d: -f1 /etc/passwd | sort تنفيذ جزئي للأمر‎ 


۸,۷ الخط 6 ۱۶ 


الان تمت عملية فرز التنفیذ «output‏ لکن لا تزال النتائج خارج الشاشة. آرسل مخرجات الأمر sort‏ إلى 


الأمر more‏ لحل هذه المشکلة: 


AW‏ اساسيات لينكس 


cut -d: -f1 /etc/passwd | sort | more 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


sysadminGlocalhost:-«$ cut -d: -f1 /etc/passwd | sort | 


backup 
bin 
bind 
daemon 
games 
gnats 
alie 
libuuid 


اا 


news 
nobody 
operator 
proxy 
TOCE 

5 0 
Sync 

sys 
sysadmin 
syslog 
uucp 


cut -d: -f1 /etc/passwd | sort | more تنفيذ الأمر‎ 


E 
اساسيات لينكمر‎ 7۳ 
للبحث عن الملفات‎ find استخدام الأمر‎ ۳ 


في هذه المهمة» سوف نستخدم الأمر find‏ للقيام بعملية البحث عن الملفات. 


الأمر find‏ هو أمر مرن جدا؛ ویصاحبه مجموعة من الخیارات options‏ مما یسمح للمستخدمین بالبحث عن 
الملفات على أساس مجموعة من المعاییر criteria‏ مثل اسم الملف filename‏ وحجمه size‏ وتاریخه date‏ 


ونوع الإذن permission type‏ ابسط صيغة للأمر هي: 
find «directory to start search» -criteria «argument for criteria»‏ 


سوف يبدأ الأمر find‏ البحث search‏ في الدليل directory‏ المحدد وبشكل متكرر recursively‏ حتى في 


الدلائل الفر .subdirectories ås‏ 
۸١‏ الخطوة ۱ 
ابحث عن الملفات التي تحتوي على اسم باش bash‏ في الدلیل الرنيسي home directory‏ : 
find ^ -name 6‏ 
وینبغي آن يكون التنفیذ مشابه لما يلي: 


:~$ find ~ -name ۳ 


/home/sysadmin/.bash logout 


/home/sysadmin/.bashrc 


وم : 


find ~ -name "*bash*" تنفیذ الأمر‎ 


تذكر أن تستخدم رمز dali‏ ~ لتمثیل الدليل الرئيسي للمستخدم الحالي للنظام .your home directory‏ 


۷۱ 


اساسیات لینکس 


۲ ۳٢ بر‎ 


ابحث عن الملفات التي تم تعدیلها أو انشانها قبل أقل من ٥‏ دقائق في الدليل المحدد specified directory‏ 
باستخدام الأوامر التالية: 
find ^/Music -mmin -5‏ 
touch -/Music/mysong‏ 


find ^/Music -mmin -5 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ find -/Music -mmin -5 
:~$ touch -/Music/mysong 
:^$ find -/Music -mmin -5 


/home/sysadmin/Music 


/home/sysadmin/Music/mysong 


وه : 


find ~/Music -m «touch -/Music/mysong «find ^/Music -mmin -5 تنفيذ الأوامر الثلائة‎ 
min -5 

الأمر find.‏ الأول لا يجد أي نتيجة؛ حيث انه لا توجد ملفات تم تعديلها في خلال الوقت المحدد في المثال وهو ٥‏ 

دقائق. اما السطر الثاني فهو يحتوي على الأمر stouch‏ الذي يقوم كما ذكرنا سابقا بتحديث الملف أو انشاءه في 

حالة عدم وجود ملف بنفس الاسم» أخيراً اعد تشغيل الأمر 5- find ^/Music -mmin‏ مرخ أخرى»ء وهو ما 


أدى إلى اكتشاف ملف جديد. 


تم عرض دليل الموسيقى Music directory‏ مع الأمر find‏ الثاني؛ وذلك لأن الدليل تم تعديله بإضافة ملف 


جديد إليه. 


٧۷۲ 


اساسیات لینکس 


Pig ۳ 


نفذ الأمر التالي للبحث عن الملفات التي حجمها أكبر من MBY‏ في الدليل /usr directory‏ 


find /usr -size ۷ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:^$ find /usr Size 701 


/usr/bin/python2.7 


/usr/lib/perl/5.14.2/auto/Encode/JP/JP.so 


/usr/lib/perl/5.14.2/auto/Encode/KR/KR.so 


/usr/share/GeoIP/GeoIPv6.dat 
/usr/share/file/magic.mgc 


وه : 


find /usr -size +2M الأمر‎ iai 


4 ۸,۳ الخطوة £ 


ابحث عن الملفات التي من نوع دليل directory‏ في الموقع المحدد: 


find /usr/share/bug - d 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


AN 


اساسیات لینکس 


find /usr/share/bug -type d‏ وم 
/usr/share/bug‏ 
/usr/share/bug/apt‏ 
/usr/share/bug/gnupg‏ 
/usr/share/bug/initramfs-tools‏ 
/usr/share/bug/procps‏ 
/usr/share/bug/cron‏ 
/usr/share/bug/file‏ 


/usr/share/bug/libmagici 


/usr/share/bug/logrotate 


/usr/share/bug/man-db 


/usr/share/bug/vim-tiny 


:~$ 


find /usr/share/bug -type d تنفیذ الأمر‎ 


٥ الخطوة‎ ٥ 


للتحقق من أن التنفيذ output‏ يعرض الدلائل «directories‏ استخدم الخيار 6)-. يستخدم الأمر find‏ الخيار 
-print‏ افتراضیا by default‏ والذي يقوم بعرض فقط أسماء الملفات file names‏ يوفر الخیار -ls‏ تفاصیل 


الملف: 


find /usr/share/bug -type d -ls 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


N 


/usr/share/bug 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


/usr/share/bug/ 


اساسیات لینکس 


sysadminGlocalhost:-$ find /usr/share/bug -type d -ls 


roor 138 Jam 29 2015 


TOGE 12 Jema 22 2015 


l roog 


root 


22:20 O CEES 

2291 (0 CONDE E 
201 

2283 O CURE R= 
gnupg 

22:37 (0 CES E 
initramfs-tools 

228007 10 CODE 12-5 
procps 

10784 O drwxr-xr-x 
cron 

10767 O CEE Se 
file 

10790 ات‎ 
libmagic1 

10793 O COO moe 
logrotate 

10/197 O COE و‎ 
man-db 

10797 O COE پو‎ 


vim-tiny 


sysadminGlocalhost: ^$ 


find /usr/share/bug -type d -ls تنفيذ الأمر‎ 


تذكر أن حرف 0 قبل الأذونات "rWwxr-x-r-x"‏ يشير إلى أن الملف هو دلیل «directory‏ آما اذا کان ملف 


فسيتم وضع علامة - للدلالة على ذلك. 


vo 


PS‏ اساسیات لينكن 


SEAE الملفات‎ 139 ۶ 


على الرغم من أن الملفات النصية الکبيرة large text files‏ يمكن رؤيتها مع الأمر «cat.‏ الا انه من غير 
المريح التمریر إلى الاعلی في الملف. بالإضافة إلى ذلكء لا يمكن عرض الملفات الکبيرة بهذه الطريقة لأن نافذة 


lines of لدیھا سعة تخزين محدودة في الذاكرة وبالتالي لا يظهر الا عدد محدد من أسطر التنفيذ‎ terminal 


.output 


استخدام الأوامر more‏ أو less‏ يسمح للمستخدم بعرض البيانات على شكل صفحة أو سطر في وقت واحد. 
آوامر pager‏ أيضا تسمح بأشکال آخری other forms‏ من التنقل navigation‏ والبحث search‏ الذي 
سنراه في هذا القسم. 

ملاحظة: الأمثلة معطاه باستخدام كلا الأمرين أكثر more‏ وأقل 5 في معظم الأوقات یقوم الأمران بنفس 
العمل» لکن الأمر أقل less‏ هو أكثر تقدما advanced‏ ولديه المزيد من الميزات features‏ تعتبر معرفته 
الأمر أكثر more‏ مهمة بمكان وذلك لأن کل توزيعات distributions‏ لينكس لديها الأمر timore‏ وفي 


المقابل الأمر أقل less‏ يوجد في بعض التوزيعات ولیس في الجميع. 


إذا كنت لا ترغب في عرض الملف بأكمله أو إخراجه كأمرء هناك العديد من الأوامر التي تكون قادرة على 
filter iiai‏ محتويات contents‏ ملف أو إخراجه. في هذا القسم سوف تتعلم استخدام امرا الرأس head‏ 
والذیل tail‏ لتكون قادر على استخراج extract‏ المعلومات information‏ من أعلى أو أسفل التنفيذ 


output‏ أو من محتويات ملف. 


۱ الخطوة‎ ۸,٤١ 


من المرجح أن يكون /etc/passwd‏ كبيراً جدا لیتم عرضه على من دون التمریر scrolling‏ على الشاشة. 


لمشاهدة عرض توضيحي demonstration‏ استخدم الأمر cat.‏ لعرض محتویات الملف Jetc/passwd‏ 


cat /etc/passwd 


NA 


^W‏ اساسیات لينكس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
loin 928 5 ۶ و‎ 2 sbim 0 0 edm 

651/5 5 3 38.38 5۱۳۵ B ۵ 
Sync:x:4:65534:sync:/bin:/bin/sync 
games:x:5:60:games:/usr/games: /bin/sh 
man:x:6:12:man:/var/cache/man: /bin/sh 
lp:x:7:7:lp:/var/spool/lpd: /bin/sh 
mail:x:8:8:mail:/var/mail: /bin/sh 
news:x:9:9:news:/var/spool/news:/bin/sh 
uucp:x:10:10:uucp:/var/spool/uucp: /bin/sh 
prozysx 7357136 720 
www-data:x:33:33:www-data:/var/www: /bin/sh 


backup:x:34:34:backup:/var/backups: /bin/sh 


list:x:38:38:Mailing List Manager:/var/list:/bin/sh 


212868209 و قاری‎ 39s /wvese/ zwi 1 28 
gnats:x:41:41:Gnats Bug-Reporting System (admin) 
:/var/lib/gnats:/bin/sh 
nobody:x:65534:65534:nobody: /nonexistent:/bin/sh 
libuuid:x:100:101::/var/lib/libuuid:/bin/sh 
syslog:x:101:103::/home/syslog: /bin/false 
bind:x:102:105::/var/cache/bind:/bin/false 
Sshd:x:103:65534::/var/run/sshd:/usr/sbin/nologin 
16ت 8ه‎ 29612 gg 710008377: 70 
Ssysadmin:x:1001:1001:S8ystem Administrator..:.:.:/home/sysadmin: 
/bin/bash 


sysadmin&localhost: ~$ 


cat /etc/passwd تنفيذ الأمر‎ 


Y $5 lil A, £, Y 


استخدم الأمر more‏ لعرض محتویات الملف Jetc/passwd‏ 


vv 


AN‏ اساسیات لينكس 


more /etc/passwd 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


zoor O OE OSE 8/۶606 2/2572 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
OLEH 5 2 5 sbim (OLS ۶ lm 

ayas 38.38 5۱۳/۵ B // eleg 0 

Gian 3-272 262234345722 8/870 66 
games:x:5:60:games:/usr/games: /bin/sh 
man:x:6:12:man:/var/cache/man: /bin/sh 
lp:x:7:7:lp:/var/spool/lpd: /bin/sh 
mail:x:8:8:mail:/var/mail: /bin/sh 
news:x:9:9:news:/var/spool/news: /bin/sh 
uucp:x:10:10:uucp:/var/spool/uucp: /bin/sh 
225927 22571 3313 arose 2 720 
www-data:x:33:33:www-data:/var/www: /bin/sh 
backup:x:34:34:backup:/var/backups: /bin/sh 
list:x:38:38:Mailing List Manager:/var/list:/bin/sh 


2 2892893893995 71 26615 ارت‎ URAL EEE sa 


gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats: 


/bin/sh 

nobody:x:65534:65534:nobody: /nonexistent:/bin/sh 
libuuid:x:100:101::/var/lib/libuuid:/bin/sh 
syslog:x:101:103::/home/syslog: /bin/false 
bind:x:102:105::/var/cache/bind: /bin/false 
Sshd:x:103:65534::/var/run/sshd:/usr/sbin/nologin 
operator 1000; 37 8 e /'itexoxe 70 


--More--(92£) 


more /etc/passwd تنفیذ الأمر‎ 


۱۷۸ 


2/530 اساسیات لينكس‎ AE 


.current data الحالية‎ 
Y $4533 رر‎ 


طالما آنك مازلت في الأمر أكثر «more.‏ فیمکنك عرض شاشة التعلیمات help screen‏ عن طريق الضغط 


:h على مفتاح‎ pressing 


ملاحظة: "--More--(9296)"‏ يدل غلی ناك في الأمر أكثر «more‏ اما النسبة ۹۲ فتدل على كمية البیانات 
وينبغي أن يكون التنفیذ مشابه لما يلي: 


72۳ اساسیات لینکس 


Most commands optionally preceded by integer argument k.  Defaults in 


Display next k lines of text [current screen 
size] 

Display next k lines of text [current screen 
size]* 

Display next k lines of text [1]* 

Scroll k lines [current scroll size: initially 11 
E 

Exit from more 

Skip forward k lines of text [1] 

Skip forward k screenfuls of text [1] 

Skip backwards k screenfuls of text [1] 

Go to place where previous search started 
Display current line number 

Search for kth occurrence of regular 
expression [1] 

Search for kth occurrence of last r.e [1] 
Execute <cmd> in a subshell 

Start uo /usr/oin/vi at current line 

Redraw screen 

Go to fem neze cile الا‎ 


Go to kth previous file [1] 


Display current file name and line number 


Repeat previous command 


تنفيذ الضغط على مفتاح h‏ للأمر more‏ 


J^. 


brackets 


«space» 


€ EEE ها‎ 


d or ctrl-D 


© OE (0) oue > 106206 0 77 


or ctrl-B 


/<regular expression> 


12 


۱۳> ۵۱ رل‎ (ue GENO 


--More-- (92%) 


2030 07 2 


٤ الخطوة‎ ٤ 
لعرض بقیة الوثيقة:‎ Spacebar اضغط على مفتاح المسافة‎ 

SPACE >‏ > 
في المثال التالي سوف تتعلم كيفية البحث في وثيقة باستخدام الأمران أكثر more‏ أو آقل less‏ 


البحث عن نمط pattern.‏ داخل الأمرين أكثر more‏ وأقل less‏ یتم بكتابة الخط المائل / يليه النمط المراد 
العثور علیه. إذا تم العثور على تطابق فينبغي أن تنتقل الشاشة إلى أول تطابق. للمضي قدما إلى التطایق التالي 
اضغط على مفتاح 0. اما مع الأمر أقل الأمر less‏ يمكنك أن تتحرك للخلف إلى التطابق السابق عن طریق 


الضغط على مفتاح (capital n) N‏ 
٥‏ الخطوة ه 


استخدم الأمر أقل less‏ لعرض كامل محتويات الملف /etc/passwd‏ ثم ابحث عن كلمة ebin‏ استخدم " 


للتحرك للأمام» وحرف IN‏ للرجوع إلى الوراء. وأخیرا انهي الأمر less pager‏ عن طریق AUS‏ الحرف 0: 


less 0 
Ibin 


nnnNNNq 


وينبغي أن يكون Sall‏ مشابه لما يلي: 


۳ 
^W‏ اساسیات لينكس 


root:x:0:0:root:/root:/bin/bash 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 

78 22 0سط 
SyS:x:3:3:sys:/dev:/bin/sh‏ 
Sync:x:4:65534:sync:/bin:/bin/sync‏ 
games:x:5:60:games:/usr/games: /bin/sh‏ 
man:x:6:12:man:/var/cache/man: /bin/sh‏ 
lp:x:7:7:lp:/var/spool/lpd: /bin/sh‏ 
mail:x:8:8:mail:/var/mail:/bin/sh‏ 
news:x:9:9:news:/var/spool/news:/bin/sh‏ 
uucp:x:10:10:uucp:/var/spool/uucp: /bin/sh‏ 
proxy:x:13:13:proxy:/bin:/bin/sh‏ 
www-data:x:33:33:www-date:/var/www:/bin/sh‏ 
backup:x:34:34:backup:/var/backups: /bin/sh‏ 
list:x:38:38:Mailing List Manager:/var/list:/bin/sh‏ 


irc:x:39:39:ircd:/var/run/ircd:/bin/sh 


gnats:x:41:41:Gnats BugReporting System(admin):/var/lib/gnats:/bin/sh 


nobody:x:65534:65534:nobody: /nonexistent:/bin/sh 
libuuid:x:100:101::/var/lib/libuuid:/bin/sh 
syslog:x:101:103: :/home/syslog: /bin/false 
bind:x:102:105::/var/cache/bind: /bin/false 
Sshd:x:103:65534::/var/run/sshd:/usr/sbin/nologin 
operator:x:1000:37::/root:/bin/sh 


/etc/passwd 


less /etc/passwd تنفیذ الامر‎ 


ثم بعد ذلك نقوم بعملیة البحث عن كلمة bin‏ كما في التنفيذ التالي: 


۸۲ 


وتاتي نتيجة البحث كما يلي: 
200۰/00/57 / : 100 : 0 : 0 :< : 1001 
sl: /SEE/ sh‏ / دنہ / daemon:x:1:1:daemon:‏ 
T:  : 2 : 2 : REESE / 20 / 8817‏ 
sn‏ / لگا / SyS:x:3:3:sys:/dev:‏ 
sync:x:4:65534:sync: / E: / ۰‏ 
games:x:5:60:games: /usr/games: (1 sh‏ 
man:x:6:12:man:/var/cache/man: /BWl/ sh‏ 
sn‏ / للا / : Ip:x:7:7:lp: /var/spool/lpà‏ 
mail:x:8:8:mail: /var/mail: /۱8/ sn‏ 
news:x:9:9:news:/var/spool/news : /BIy/ sh‏ 
uucp:x:10:10:uucp: /var/spool/uucp : 8/7‏ 
proxy:x:13:13:proxy: / RE: / 8 sh‏ 
www-data:x:33:33:www-data:/var/www: / Bi sh‏ 
backup:x:34:34:backup: /var/backups : /۱/ sh‏ 
sn‏ لا / list:x:38:38:Mailing List Manager: /var/üst:‏ 
sh‏ الگا / irc:x:39:39:ircd:/var/run/ircd:‏ 
gnats:x:41:41:Gnats BugReporting System (admin) :/var/lib/gnats: /۱18/ sh‏ 
nobody:x:65534:65534:nobody: /nonexistent: /BBli/ sn‏ 
libuuid:x:100:101::/var/lib/libuuid: /Blly sn‏ 
syslog:x:101:103: : /home/sysloo : / ۵/۵۱2۰‏ 


x : 102 : 105 : : /var/cache / 1955919 : /8W/ false‏ :اوا 


sshd:x:103:65534::/var/run/sshd: /usr/ اه‎ nolooin 


operator:x:1000:37: :/root: /BBi/ sh 


نتيجة البحث عن كلمة bin‏ 


JAY 


۸۶ 
AS‏ اساسیات لینکس 
ونستخدم حرف للانتقال الى النتيجة التالية للبحث كما يظهر في الشكل التالي: 


daemon:x:1:1:daemon: / دن‎ / siid: / 42/5 

BE :  : ۰2 : REESE / 1: 8817 
sys:x:3:3:sys:/dev: // sh 
sync:x:4:65534:sync: / BE: / sync 
games:x:5: 60:games:/usr/games : /'8 sh 
man:x: 6:12:man:/var/cache/man: /BWl/ sh 
Ip:x:7:7:lp: /var/spool/lpà : // sh 
mail:x:8:8:mail: /var/mail: ۱۸۰ i sh 

news:x:9: 9:news:/var/spool/news : /BIy sh 
uucp:x:10:10:uucp:/var/spool/uucp: /8N/ sh 
proxy:x:13:13:proxy: /BEER: / ۹ / sh 
www-data:x:33:33:www-data:/var/www : / 18 / sh 
backup:x:34:34:backup: /var/backups: / Bg sh 
list:x:38:38:Mailing List Manager:/var/list: ۸۰ i sh 


irc:x:39:39:ircd:/var/run/ircd: / الگا‎ / sh 


gnats:x:41:41:Gnats BugReporting System (admin) :/var/lib/gnats : /BIy/ sh 


nobody:x:65534:65534:nobody: /nonexistent: /BEli/ sn 
libuuid:x:100:101::/var/lib/libuuid: /IIly sh 

syslog:x:101:103: : /home/syslog : / ۵ / false 

x:102:105::/var/ cache / El : / I false‏ : د ھا 

Sshd:x:103:65534: :/var/run/sshd:/usr/sIl/nolocin 

operator:x:1000:37: : /root : /BB]i/ sh 

sysadmin:x:1001:1001:System Administrator, , , :/home/sysadmin: 8/7 


(END) 


تنفيذ dall‏ عن النتيجة التالية عن طريق حرف n‏ 


A 


اساسیات لینکس 


واخيراًء للعودة الى نتيجة البحث السابقة نقوم بالضغط على الحرف N‏ كما يظهر ادناه: 


root:x:0:0:root:/root:/M/basn 
daemon:x:1:1:daemon: /usr / siii: / SEER/ sh 

BE : x : 2 : 2 ۰5۴3۵ : / 1: 88877 

Sys:x:3:3:sys:/dev: / لگا‎ / sn 

sync:x:4:65534:sync: / BE: / sync 
games:x:5:60:games:/usr/games : /۱8/ sh 
man:x:6:12:man:/var/cache/man: /۱۱/ sh 

Ip:x:7:7:lp: /var/spool/lpa : / 3/2 
mail:x:8:8:mail:/var/mail: /۱8/ sn 
news:x:9:9:news:/var/spool/news :// sn 
uucp:x:10:10:uucp: /var/spool/uucp : / BN sh 
proxy:x:13:13:proxy : / E: / ۹ sn 
www-data:x: 33 : 33 :www-data: /var/ www : / 18 / sh 
backup:x:34:34:backup: /var/backups: / الگا‎ sn 
list:x:38:38:Mailing List Manager: /var/list : / lsh 
irc:x:39:39:ircd:/var/run/ircd: (8! sh 
gnats:x:41:41:Gnats BugReporting System (admin) :/var/lib/gnats: /۱18/ sh 
nobody:x:65534:65534:nobody: /nonexistent: / EJ sh 


libuuid:x:100:101::/var/lib/libuuid: /Blly sn 


syslog:x:101:103: :/home/syslog: / : false 


۱988/0 :x : 102 : 105 : :/var/cache 0 : / ۱/212۰ 
Ssshd:x:103:65534::/var/run/sshd: /usr/ AN nologin 


operator:x:1000:37: : /root : /BBi/ sh 


نتيجة الضغط على حرف لا 


۱۸۵ 


اساسیات لینکس 


يختلف الأمر more‏ عن الأمر dess‏ حيث ان الأول یخرج تلقائيا automatically‏ عند الوصول إلى 


نهاية الملف» اما الاخر فيجب الضغط على مفتاح 0 لأنهاء عمله. 


٦ ر۸ الخطوة‎ ٦ 


يمكنك استخدام الأمر رأس head‏ لعرض الجزء العلوي من ملف. افتراضيا؛ سيقوم الأمر رأس head‏ بعرض 


آول عشرة أسطر من الملف: 


head 0 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ head ۵ 
122872 5 x2 0207 ۶ ۶٠۷ roots ۷٣ 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
lolum 8588.2 2 2 gentia a Moras OES 
831485226898981 20 
Sync:x:4:65534:sync:/bin:/bin/sync 
games:x:5:60:games:/usr/games: /bin/sh 
man:x:6:12:man:/var/cache/man: /bin/sh 
lp:x:7:7:lp:/var/spool/lpd: /bin/sh 


mail:x:8:8:mail:/var/mail:/bin/sh 


news:x:9:9:news:/var/spool/news: /bin/sh 


وم : 


head /etc/passwd تنفیذ الأمر‎ 


۷ الخطوة‎ ٧ 


إستخدم الأمر ذيل tail‏ لعرض آخر عشر اسطر من الملف /etc/passwd‏ 


۱۸۹ 


جو E‏ 
AW‏ اساسيات لينكس 


tail /etc/passwd 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ tail 0 


list:x:38:38:Mailing List Manager:/var/list:/bin/sh 


EEE E JIE :26615 we / swim LECCE , el 

gnats:x:41:41:Gnats Bug-Reporting System (admin):/var/lib/gnats 
:/bin/sh 

nobody:x:65534:65534:nobody: /nonexistent:/bin/sh 
libuuid:x:100:101::/var/lib/libuuid:/bin/sh 
syslog:x:101:103::/home/syslog: /bin/false 
bind:x:102:105::/var/cache/bind: /bin/false 
Sshd:x:103:65534::/var/run/sshd:/usr/sbin/nologin 

OPE BREESE SS 1000:37: 5 //itexoxe 8 ٦ 

Sysadmin:x:1001:1001:S8ystem Administrator..:.:.:/home/sysadmin: 


/bin/bash 


tail /etc/passwd الأمر‎ 3s 


۸۸ الخطوة ^ 


استخدم أمر رأس head‏ لعرض آول سطرين من الملف Jetc/passwd‏ 


head -2 0 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


AY 


اساسیات لینکس 


:~$ head -2 /etc/passwd 


72665 225842020522591 2 / roots 780 


daemon:x:1:1:daemon:/usr/sbin:/bin/sh 


$ 


head -2 /etc/passwd تنفیذ الأمر‎ 


48 الخطوة ۹ 


نفذ السطر التالي للاسناد مخرجات الأمر 8ا الى الأمر الذیل etail‏ وبالتالي عرض اخر خمسة أسماء من ملفات 


Jete الدليل‎ 


ls /etc | tail -5 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ وا‎ /etc | tail -5 


update-motd.d 
updatedb.conf 
vim 

wgetrc 


xml 


تنفیذ الأمر 5- ls /etc | tail‏ 
كما رأينا في الأمرین الرأس head‏ والذيل stail‏ فان تنفیذ output‏ عشرة اسطر يكون افتراضيا. يمكنك أيضا 
إستخدام خیار # - (أو يمكنك استخدام الخيار # 0- ۰ حيث ان علامة الشبكة # ترمز لعدد اسطر الشخرجات). 
ايضاً كلا الأمران يمكن أن یستخدما لقراءة الادخال القياسي read standard input‏ من القناة التي تستقبل 


.command من الأوامر‎ receives output iil 


A۸ 


اساسیات لینکس 


لقد رأينا آیضا الإختلاف بين الأمرين الرأس head‏ والذيل «tail‏ حيث ان الأول يبدأ عد اسطر التنفيذ من الجزء 
العلوي من البيانات «top of the data‏ في حين ان الأمر الذيل يعد اسطر التنفیذ من الجزء السفلي للبیانات 
Lal bottom of the data‏ هناك بعض الاختلافات الاضافية بين هذين الأمرين كما سيتم توضحیه في 


المهام القادمة. 


۸۰ الخطوة ۱۰ 


بجانب الطريقة السابقة لتحديد عدد الاسطرء فإننا نستطيع ومع الأمر رأس head‏ استخدام الخیار #- t-n‏ 
لاحظ ان رمز (-) آمام رمز #. Cus‏ ان رمز الشبكة # يرمز لعدد الاسطر التي سيتم استبعادها exclude‏ 
وتحدیداً من الجزء السفلي من التنفيذ. بعبارة أخرى فان الامر head -n -20 /etc/passwd‏ يقوم بانقاص 
عدد ۲۰ سطر من العدد الكلي للأسطر بداية من الأسفل. على سبیل «Jal‏ إذا کان الملف /etc/passwd‏ 
يحتوي علی ٤٢‏ سطر فان الأمر التالي سوف یعرض الاسطر الأربعة الأولی من السطر ١‏ الی السطر ٤‏ وبالتالي 


استثناء الأسطر العشرين الأخيرة: 


head -n -20 ۷0 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ head -n -20 /etc/passwd 


root:x:0:0:root:/root:/bin/bash 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
lenta و 2 م ده‎ 2110 lol al 8 
857۸982838 - - ۵ 

56 


head -n -20 /etc/passwd تنفيذ الأمر‎ 


۱۸۹ 


230 اساسیات لینکس‎ ES 


٥‏ البحث عن النص عن طریق التعابیر العادیة 


في هذه المهمة» سوف نستخدم مجموعة الأوامر grep‏ مع التعابير العادية regular expressions‏ من أجل 
البحث عن سلسلة string‏ محددة من الأحرف في قطعة stream‏ من البيانات ؛ على سبيل المثال ملف نصي 


text file 


یستخدم الأمر grep‏ مع التعابیر العادية الأساسية basic regular expressions‏ والاحرف الخاصة 
special characters‏ مثل أحرف wildcards Js!‏ التي تطابق Bui match‏ البيانات data‏ 


5 يقوم الأمر grep‏ بارجاع كامل السطر الذي يحتوي على النمط المطابق. 


الخيار -E‏ يمكن اضافته للأمر grep‏ لإجراء عمليات بحث مع التعابير العادية الطويلة extended regular‏ 


5 و وهناك أيضا طريقة آخری لاستخدام التعابير العادیة الطويلة وهي استخدام الأمر 60۲60. 


يستخدم الأمر fgrep‏ لمطابقة الأحرف الحرفية citeral characters‏ وتجاهل المعنی الخاص من احرف 


regular expression characters التعبير العادية‎ 
۱۸ انح‎ Aye; 


إن ابسط شکل للامر grep‏ هو البحث عن سلسلة معطاه من الاحرف «string of characters‏ مثل البحث 
عن SSD‏ في الملف /etc/passwd‏ الأمر grep‏ سیقوم بطباعة کامل السطر entire line‏ والذي یوجد 


به التطابق :match‏ 


cd /etc 


grep sshd passwd 


وينبغي أن يكون التنفیذ مشابه لما يلي: 


۱۹۰ 


اساسیات لینکس 


ES uel ۵ 


$ grep sshd passwd 


SE 103: 655345 ۵ و‎ EUR :/usr/sbin/nologin 


$ 


grep sshd passwd «cd /etc تنفیذ الأمرين‎ 


Y لخطوة‎ | ۸,۵,۲ 


التعابیر العادية Regular expressions‏ سوف تطابق کل حرف every single instance‏ من ha‏ 


:specified pattern محدد‎ 


grep root passwd 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


5 grep root 35م‎ 0 


522 0 7 :/bin/bash 


operator:x:1000:37::/ :/bin/sh 


grep root passwd تنفیذ الأمر‎ 


لاحظ ان الضوء الأحمر يشير إلى ما يتطابق بالضبط. يمكنك أن ترى أيضا أن كافة ما یظهر في الجذر 


occurrences of root‏ متطابق matched‏ في كل سطر. 


۸,۵,۳ الخطوة ۳ 


aï regular expressions Ae یمکنك استخدام تعبیرات‎ limit the output للحد من المخرجات‎ 


نمط أكثر دقة „precise pattern‏ على سبیل المثال ادخال الحرف )^( بستخدم لعمل تتطابق مع نمط pattern‏ 


س0 اساسیات لینکس 


في بداية السطر. لذلك عند تنفیذ سطر الأوامر التالي» الاسطر التي تبدأ بالجذر فقط root‏ يجب أن تكون مطابقة 


ومعروضه باللون الاحمر: 
grep "^root' 0‏ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ grep '^root' passwd 


520910 e (0) e roor: AE OEE 7 


$ 


grep ۲۸۲۵0۵ passwd تنفیذ الأمر‎ 


لاحظ أن هناك حالتين إضافيتين من AGIS‏ جذر root‏ ولكن فقط واحدة تظهر باللون الأحمر وهي الموجودة في 


بدایة السطر. 


أفضل الممارسات: استخدم علامات الاقتباس المفردة لا المزدوجة مع التعبيرات العادية regular‏ 


5 وذلك لمنع برنامج القشرة shell‏ من محاولة تفسیر ها interpret‏ 


٤ الخطوة‎ ٤ 


طابق النمط sync‏ في أي مكان على السطر: 


grep 'sync' passwd 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


اساسیات لینکس 


$ grep 'sync' passwd 


dig 7 2 forms ٤۷‏ 2 مره 


$ 


grep 'sync' passwd تنفیذ الأمر‎ 


٥ الخطوة‎ ٥ 


استخدم الرمز 5 لتجد التطابق مع sync haill‏ في نهاية السطر: 


grep 'sync$' 06 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ grep 'sync$' passwd 


syncs 84e 65/5/34 ۰577088 /5 و‎ 7 
$ 


grep 'sync$' passwd تنفیذ الأمر‎ 


الأمر الأول يطابق کل حرف من الاحرف, اما الثاني يطابق فقط المثیل في نهاية السطر. 


٦ الخطوة‎ 7 


استخدام حرف النقطة period‏ (.) لمطابقة أي حرف. على سبيل المثال» نفذ الأمر التالي لمطابقة أي حرف 


متبوع بحرف y‏ 


grep '.y' 0 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


: 
ېو 
7۳ اساسیات لینکس 


$ grep '.y' passwd 


5 9255 318315 اكات 7 5 18ت‎ 
nc:x:4:65534:sync:/bin:/bin/sync 
proxy:x:13:13:proxy:/bin:/bin/sh 
gnats:x:41:41:Gnats Bug-Reporting stem 
(admin) :/var/lib/gnats:/bin/sh 
nobody:x:65534:65534:nobody: /nonexistent:/bin/sh 
slog:x:101:103::/home/syslog: /bin/false 
sadmin:x:1001:1001:S8ystem Administrator....:/home/sysadmin: 


/bin/bash 


grep '.۷' passwd تنفيذ الأمر‎ 


V الخطوة‎ ۸,۵,۷ 


حرف المستقيم " | cU‏ أو ما يسمى بعامل التناوب operator‏ ۰۵116۲0211010 يستخدم لعمل جملة أو Or‏ 


۲ علی سبيل المثال» نفذ ما يلي لمحاولة مطابقة !ما الجذر sshd‏ أو المشغل :operator‏ 


grep 'sshd|root|operator passwd 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ grep 'sshd|root|operator' passwd 


$ 


grep 'sshd|root|operator' passwd تنفیذ الأمر‎ 


نلاحظ أن الأمر Y grep‏ يميز المدخلات افتراضيا. وبالتالي فهو ينظر الى الحرف المستقیم " | " كحرف عادي 
plain character‏ في نمط ما ويجب أن یتطابق للحصول على نتيجة. ولحل تلك المشكلة» يجب استخدام اما 
grep -E‏ أو ۰۵0۲60 وهو ما يسمح باستخدام التعابیر العادية الطويلة extended regular‏ 


expressions‏ ہما في ذلك حروف التناوب alternation‏ مثل الحرف المستقيم 


۹٤ 


اساسیات لینکس 


۸ الخطوة ۸ 


استخدام رمز التبديل -E‏ للسماح للأمر grep‏ للعمل في الوضع الموسع extended mode‏ من أجل التعرف 


على عامل التناوب :alternation operator‏ 


grep -E 'sshd|root|operator' 06 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ grep -E 'sshd|root|operator' passwd 


4 :/bin/bash 


2x3 103: 655343 84/2/27 :/usr/sbin/nologin 


J/ oim eat‏ 2 ۷ 8 )10010 وه 


grep -E 'sshd|root|operator' passwd تنفيذ الأمر‎ 


۹ الخطوة ۹ 


هنا فإننا نستخدم تعبير عادي موسع extended regular expression‏ آخرء وهذه المرة مع الأمر 


:non و‎ nob لکن الاختلاف هو ان التطابق یتم مع نمط مجموعة كاملة. مثل السلاسل‎ «egrep 


egrep 'no(b|n)' passwd 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ egrep 'no(b|n)' passwd 


ody s2: 655345655348 ody: / existent:/bin/sh 


egrep 'no(b|n)' passwd تنفيذ الأمر‎ 


اساسیات لینکس 


ملاحظة: الأقواس parenthesis‏ ( ) تستخدم للحد من المدی scope‏ للحرف |. مثلاً nob|n‏ النمط بدون 


الاقواس قد يعني تطابق اما nob‏ أو an‏ 


٠١ الخطوة‎ ۸,٠۰ 


يمكن أيضا استخدام الاقواس المربعة [ ] لمطابقة حرف واحد» ولكن على عكس النقطة period‏ (.)ء يتم 
استخدام [] لتحديد بالضبط ما الحرف الذي ترغب في مطابقته. على سبيل المثال» إذا كنت تريد أن تطابق حرف 


رقمي» يمكنك التحديد من [۰-۹].نفذ الأمر التالي: 


head passwd | grep '[0-9]' 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


$ head passwd | grep '[0-9]' 
root- x- (0) 8 0: 1۶6۵۴ 2/222 707٦ 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
bimg: 28۶۰۰9008 2 
ELE Ex ,۹ك ٴ3‎ ٣٥ 
Sync:x:4: :Sync:/bin:/bin/sync 
games:x:5:60:games:/usr/games: /bin/sh 


man:x:6:12:man:/var/cache/man: /bin/sh 


lp:x:7:7:lp:/var/spool/lpd: /bin/sh 


mail:x:8:8:mail:/var/mail:/bin/sh 
news:x:9:9:news:/var/spool/news: /bin/sh 


$ 


head passwd | grep ']0-9[' تنفيذ الأمر‎ 


ملاحظة: تم استخدام الأمر الرأس head‏ للحد من إخراج output‏ الأمر grep‏ 


اساسیات لینکس 


۹۱۹ الخطوة ۲۱ 


افترض أنك ترید البحث عن نمط يحتوي على سلسلة من ثلاثة أرقام. یمکنك استخدام الاقواس ( ) مع عدد ما 
للتعبیر بأنك ترید تكرار lai‏ محدد ولعدد من المرات. على سبيل المثال: (Y)‏ »لاحظ إن استخدام تصفیات رقمية 


:grep من‎ extended mode يتطلب الوضع الموسع‎ numeric qualifier 
grep -E '[0-9](3)' 06 
وينبغي أن یکون التنفيذ مشابه لما يلي:‎ 


$ grep -E '[0-9](3)' 060 
29 0 4 345 inm O ILE O 6 
nobody:x: 34: 34:nobody:/nonexistent:/bin/sh 
libuuid:x: : ::/var/lib/libuuid:/bin/sh 
syslog:x: : : : /home/8syslog: /bin/false 
37ط‎ : ::/var/cache/bind:/bin/false 
sshd:x: 8 34::/var/run/sshd:/usr/sbin/nologin 


operator:x: 018 3778/6896 ھ72‎ 


Sysadmin:x: ik: 1:System Administrator..:.:.:/home/sysadmin: 


/bin/bash 


grep -E '[0-9]{3} passwd تنفیذ الأمر‎ 


> اساسیات لینکس 230 
Ni‏ 


اد هه رب تن بان 


المعمل التاسع — البرمجة الاساسية 


Basic Scripting 


۸ 


230 اساسیات لینکس‎ ^W 
مقدمة‎ ٩۱ 


هذا هو المعمل التاسع آوامر البرمجة Scripting Commands‏ في لینکس. عن طريق آداء هذا التمرین؛ 
سوف تتعلم كيفية استخدام محرر أ۷ لانشاء برنامج نصي بسیط في القشرة basic shell scripts‏ باستخدام 


آوامر القشرة shell commands‏ والمتغیرات variables‏ وجمل التحکم .control statements‏ 
e.‏ استخدام محرر ۷ لإنشاء وتحرير الملفات النصية. 
٭ إنشاء البرامج النصية البسيطة في القشرة. 


o‏ انشاء البرامج النصية في القشرة مع التنفيذ المشروط. 


ه استخدام الحلقات في برنامج النصية لغرض التكرار. 
۲ تحرير النص الأساسى 


معظم توزيعات distributions‏ لينكس لديها أكثر من محرر نصوص text editor‏ واحد. محرر النص يمكن 
ان يحتوي على محرر نص بسيط فقط simple text-only editors‏ مثل المحرر «nano‏ أو يكون لديه 


محرر رسومي graphical editors‏ مثل المحرر .gedit‏ 


في هذه المهمة» سوف تستكشف بعض ممیزات تحرير النصوص الأساسية للمحرر vi editor‏ جميع توزيعات 
لينكس لديها نسخ من المحرر أ۷ والذي يعتبر محرر نص قوي خاص بالتدريب ولكنه قادر على أداء مجموعة 


متنوعة من مهام تحرير النص text editing tasks‏ 


محرر yi‏ له قسمان رئيسيان هما وضع الأوامر command‏ ووضع الإدراج insert.‏ الوضع الاول تستطيع 
فيه القيام بالعملیات؛ Jis‏ الملاحة navigation‏ والبحث searching‏ والحفظ saving‏ والخروج من المحرر 


„document الوضع الثاني وهو الادراج؛ وفيه نستطيع كتابة أي نص في المستند‎ Ul exiting the editor 


fe‏ کے 
^W‏ اساسیات لینکس 2230 
۱ الخطوة ) 
vi myfile‏ 
اکتب | للدخول إلى وضع إدراج insert‏ في المحرر vi‏ ثم أدخل النص التالي: 
i‏ 
Welcome to the vi editor.‏ 
It is a very powerful text editor.‏ 
Especially for those who master it.‏ 
ثم اضغط على مفتاح Esc‏ لترك وضع الإدراج insert mode‏ أكتب wg‏ لكتابة الملف في القرص ثم 
الخروج. 
ESC >‏ > 
wq‏ 
ملاحظة: سنتم تغطية کل من الأوامر السابقة بمزيد من التفصیل لاحقا في هذا المعمل؛ حیث أن الغرض من 
الخطوة السابقة انشاء ملف والعمل عليه خلال هذا الدرس. 
۲ الخطوة Y‏ 
استدعي المحرر vi editor‏ لتعديل الملف الذي قمت بإنشائه. عندما یتم استدعاء «vi editor‏ تصبح في وضع 
الأوامر ولیس الادراج: 
y ۰ ۰‏ | 


A‏ اساسیات لینکس 


vi myfile 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


elcome to the wu editor- 


It is a very powerful text editor. 


Especially for those who master it. 


"myfile" 3 lines, 97 characters 


vi myfile تنفیذ الأمر‎ 


لاحظ في أسفل الجانب الايسرء یتم عرض اسم الملف file name‏ وعدد الاسطر number of lines‏ و عدد 


الحروف number of characters‏ في الملف. 


command mode الأوامر‎ 


EN المفتاح‎ 


j‏ يتحرك المؤشر للأسفل سطر واحد (ممائل لمفتاح سهم للأسفل) 


K‏ يتحرك المؤشر فوق السطر (ممائل لمفتاح سهم للأعلى) 


ےم 


يتحرك المؤشر إلى اليمين حرف واحد (ممائل لمفتاح سهم لليمن) 


يتحرك المؤشر إلى الیسار حرف واحد (مماثل لمفتاح سهم للیسار) 


= I 


يتحرك المؤشر إلى بداية الكلمة التالية 
2 يتحرك المؤشر إلى نهاية الكلمة 


0 يتحرك المؤشر إلى بداية الكلمة السابقة 


جدول مفاتيح التحكم لتحريك المؤشر في وضع الأوامر 


تحذیر: إذا قمت بالضغط على أي مفاتيح آخری غير المذكورة أعلاه» فربما تنتقل الى وضع الادراج insert‏ 
mode‏ . لا داعي للقلق! اضغط على مفتاح Esc‏ للخروج من ذلك الوضع: ثم في وضع الأوامر أكتب 0۱: 
+ مفتاح „Enter‏ وهذا ينبغي أن يخرجك من المحرر vi‏ دون حفظ أي تغييرات. ثم نفذ vi myfile‏ للعودة 


والعمل على المحرر vi‏ 


٤ الخطوة‎ ٤ 


المزید عن المحرر [۷: اضغط على المفاتيح التالية ولاحظ كيف يتحرك المؤشر: 


- 7 
Me‏ 
D‏ اساسیات لینکس 2230 
۳ الخطوة Y‏ 
اضغط press‏ على كل من المفاتيح التالية مرتين ولاحظ كيف يتحرك المؤشر cursor‏ تذکر e‏ في وضع 


٠‏ اساسيات لينكس 

المفتاح الوظیفة 

$ يتحرك المؤشر إلى نهاية السطر الحالي (ممائل لمفتاح النهاية (End‏ 
(zero)‏ 0 يتحرك المؤشر إلى بداية السطر الحالي (ممائل لمفتاح البداية (Home‏ 
36 يقفز إلى السطر الثالث nG)‏ يقفز إلى السطر (n‏ 

10 یقفز إلی السطر الاول 

6 يقفز إلى السطر الاخیر 


جدول فيه المزيد من مفاتيح التحكم لتحريك المؤشر في وضع الأوامر 


٥‏ الخطوة ه 


يتم نقل المؤشر cursor‏ إلى بداية الكلمة very‏ عن طريق الضغط على المفاتيح التالية: 


8 


يجب أن يكون المؤشر على حرف ۷ في كلمة very‏ كما هو مبين آدناه: 


Welcome to the vi editor. 


It is a Mery powerful text editor. 


Especially for those who master it. 


اساسیات لینکس 


٦ الخطوة‎ ٦ 


احذف كلمة very‏ عن طريق الأمر dw‏ (حذف كلمة word‏ 061616): 


dw 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


TE xe اج‎ Bowertul text 20027 


Especially for those who master it. 


۷ الخطوة ۷ 


التراجع عن العملية الأخيرة: 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


It is a Mery powerful text editor. 


Especially for those who master it. 


اساسیات لینکس 


۸ الخطوة ۸ 


حذف کلمتین: 


2dw 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


It is a Bext editor. 


Especially for those who master it. 


2dw الأمر‎ ia 


۷۹ الخطوخ 4 


التراجع عن العملية الأخيرة: 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


Welcome to the vi editor. 


lg iS d Mery powerful text editor. 


Especially for those who master it. 


E Je 
اساسيات لینکس‎ 7۳ 


۱۰ الخطوة‎ ٠ 
اضغط على الحرف × آربع مرات لحذف أربعة أحرف:‎ 

XXXX 
وينبغي أن يكون التنفيذ مشابه لما يلي:‎ 


Welcome to the vi editor. 


Ji 12 & [powerful text editor. 


Especially for those who master it. 


تنفیذ الأمر XXXX‏ 
۱ الخطوة ۱۱ 
التراجع عن العمليات الاربعة الأخيرة واستعادة الأحرف المحذوفة: 
4u‏ 
وينبغي أن يكون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


lr دعق & گلا‎ powerful text editor. 


Especially for those who master it. 


اساسیات لینکس 


د الخطوة ۲۲ 


حذف ٤١‏ حرفا: 


14× 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


De TS اج‎ Bext editor. 


Especially for those who master it. 


تنفيذ الأمر ×14 


۳ الخطوة ۱۳ 


التراجع عن العملية الأخيرة: 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


Welcome to the vi editor. 


IE oe & Mery powerful text editor. 


Especially for those who master it. 


تنفیذ الأمر U‏ 


اساسیات لینکس 


5 الخطوة 1£ 


لحذف الأحرف الخمسة إلى يسار المؤشر اكتب ٥‏ ثم X‏ 


5X 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


1 Mery powerful text editor. 


Especially for those who master it. 


تنفیذ الأمر 5X‏ 


۵ الخطوة 16 


التراجع عن العملية الأخيرة: 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


TE fs a very powerful text editor. 


Especially for those who master it. 


اساسیات لینکس 


١5 الخطوة‎ ٦ 


حذف السطر الحالي: 


00 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


Welcome to the vi editor. 


specially for those who master it. 


تنفیذ الأمر dd‏ 


۷ الخطو: ۱۷ 


مهما كان ما تم حذفه أو قصه فانه یمکن لصقه. الصق الاسطر المحذوفة تحت السطر الحالي: 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


Welcome to the vi editor. 


Especially for those who master it. 


8 is a very powerful text editor. 


اساسیات لینکس 


20 


۱۸ الخطوة‎ Y, YA 
للتراجع عن العملیتین الماضیتین:‎ 


Welcome to the vi editor. 


8 is a very powerful text editor. 
Especially for those who master it. 


وينبغي أن یکون التنفيذ مشابه لما يلي 


تنفیذ الأمر 20 


200 


۹ القطية ۱۹ 


حذف سطرین الحالي والذي يليه: 


elcome to the vi editor. 


وينبغي أن یکون التنفيذ مشابه لما يلي 


تنفیذ الأمر 200 


۰ الخطوة ۲۰ 
۳۱۰ 


التراجع عن العملية الأخيرة: 


اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


8 is a very powerful text editor. 


Especially for those who master it. 


تنفيذ الأمر U‏ 


۲٢ الخطرۃ‎ ۹ 


الانتقال إلى الكلمة الرابعة ثم الحذف من المكان الحالي إلى نهاية السطر باستخدام (]: 


4w 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


li 3e & موی‎ 


Especially for those who master it. 


تنفیذ الأمرين ۰4۷۷ D‏ 


يحذف الأمر 08 أيضا إلى نهاية السطر. لان 8 كما تقدم تعني الانتقال إلى نهاية السطر. وبالتالي فان 08 سوف 


تحذف إلى نهاية السطر. 


اساسیات لینکس 


BEDAE 


التراجع عن العملية الأخيرة: 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


li 15 ٣٦ Bowerful text editor. 


Especially for those who master it. 


تنفیذ الأمر U‏ 


۳ الخطوة ۲۳ 


ضم سطرين» الحالي والذي يليه عن طريق كتابة حرف ل: 


وينبغي أن يكون التنفیذ مشابه لما يلي: 


Welcome to the vi editor. 


It is a very powerful text editor. Especially for those who master it 


اساسیات لینکس 


٤٢ الخطوة‎ ٤ 


التراجع عن العملية الأخيرة: 


Welcome to the vi editor. 


li 15 ٣٦ Bowerful text editor. 


وينبغي أن یکون التنفيذ مشابه لما يلي 


Especially for those who master it. 


تنفيذ الأمر با 


Yo الخطوة‎ Y, Yo 


نسخ أو نثر الكلمة الحالية: 


عند نسخ النص» لا يحدث أي تغيير على الشاشة. 


نب وو ۳٢‏ ۲۹ 


لصق (أو "وضع") كلمة منسوخة قبل المؤشر الحالي: 


yw 


اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


It is a very power fulpowerful text editor. 


Especially for those who master it. 


۷ الخطوة ۲۷ 


التراجع عن العملية الأخيرة: 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. 


It is a very Bowertul text editor. 


Especially for those who master it. 


تنفيذ الأمر ںا 


۸ الخطوة ۲۸ 


انتقل إلى السطر الأول» ثم ضم ثلاثة أسطر مع بعضها البعض: 


اساسیات لینکس 


1G 


3J 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Welcome to the vi editor. It is a very powerful text editor. Especiall 
y EOE 608998 6 


master it. 


تنفیذ لمفاتیحي التحكم بالمؤشر 4G‏ ل3 


۹ الخطوة ۲۹ 


التراجع عن العملية الأخيرة: 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


elcome to the vi editor. 


It is a very powerful text editor. 


Especially for those who master it. 


تنفيذ الأمر با 


۰ الخطوة ۳۰ 
البحث وحذف کلمة text‏ (أضف مسافة قبل كلمة text‏ و بعدها): 


١١٥٢ 


^W‏ اساسیات لینکس 


:Ses/ text //g 
وينبغي أن يكون التنفيذ مشابه لما يلي:‎ 


Welcome to the vi editor. 


8 is a very powerfuleditor. 


Especially for those who master it. 


55287 tese //g 


:%5/ text //g تنفيذ الأمر‎ 


AREA 1‏ لي 


انتقل إلى بداية الملف» ثم اضغط | للدخول إلى وضع إدراج insert mode‏ لإضافة نص: 


D‏ اساسيات لينكس 

المفتاح وظيفته 

16 اذهب إلى بداية الملف, 

i‏ الدخول إلى وضع إدراج. 

.and اضافة نص إلى وثيقة مع مسافة بعد‎ Hello and 


Hello and «i «1G جدول یصف الأوامر‎ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello andfelcome to the yi editor, 


It is a very powerful text editor. 


Especially for those who master it. 


Hello and «i 4G تنفیذ الأوامر‎ 


YY الخطوة‎ "۲ 


اخرج من وضع الادراج الحالي وقم بالعودة إلى وضع الأوامر عن طريق الضغط على مفتاح الهروب 


:Escape key 


> ESC < 


۳ الخطوة ۳۳ 


التقدم بالمژشر مسافة واحدة عن طریق الضغط على حرف ] لوضع المؤشر على حرف ۷ ثم الضغط على رمز 


~ تیلدا tilde‏ عن طریق ( ` + Shift‏ ): 


اساسیات لینکس 


FERT المفتاح‎ 


i‏ ۰ صغيرة و التحرك مسافة واحدة إلى الأمام 


Shift +" 5‏ لكتابة رمز التیلدا 


جدول لوصف الأمرين | و ہ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and wAlcome to the vi editor, 


It is a very powerful text editor. 


Especially for those who master it. 


تنفیذ الأمرين d‏ ^ 


۳ الخطوة‎ 4, Y, Y£ 


احفظ الملف واضغط على مفتاح الخروج Esc‏ لضمان أنك في وضع الأوامر. ثم اكتب Ww‏ ثم اضغط على 


المفتاح ادخال: 


۵ الخطو 6 ۳۵ 


اضغط على Enter‏ لتأکید التغییر» لاحظ الرسالة في أسفل الیسار يشير إلى ملف قد تمت کتابه: 


> Enter > 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


اساسیات لینکس 


"7۶118" 3 lines, 102 characters written 


تنفيذ الضغط على مفتاح الادخال 


۳٣ الخطوة‎ ٦ 


انتقل إلى الفراغ بين كلمة powerful‏ وكلمة editor‏ في السطر الثاني كما هو مبين في الصورة آدناه. يمكنك 


القيام بذلك بالضغط على ز تلیها 101 أو استخدام مفاتیح الأسهم: 


3 


المفتاح الوظیفة 
j‏ الانتقال إلی السطر في الاسفل 


٠ 101‏ تليها ۱۰" صغيرة 


جدول يصف الأمرين » 101 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 


It is a very powerfullleaitor. 


Especially for those who master it. 


تنفيذ الأمرين «j‏ 101 


۷ الخطوة ۳۷ 


آدرج كلمة text‏ على يمين المؤشر عن طریق الضغط على حرف . سوف بتحرك الموشر إلى اليمين ویتم 


الانتقال إلى وضع الادراج. اکتب کلمة text‏ متبوعة بمسافة كما هو مبين في الصورة أدناه: 


Me 

A‏ اساسيات لينكس 
المفتاح وظیفته 

3 الدخول إلى وضع الإدراج 
text‏ نص متبوعا بمسافة 


text «a جدول یصف‎ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 


It is a very powerful text Baitor. 


Especially for those who master it. 


تنفیذ الأمرين ۰2 text‏ 


۸ الخطوة ۳۸ 


الخروج من وضع الادراج عن طریق الضغط على مفتاح هروب „Esc‏ 


> ESC > 


۹ الخطو: ۳۹ 


انشی سطر nas‏ فارغ تحت السطر الحالي عن طریق کتابة حرف 0 صغير: 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


۲۲۰ 


جو E‏ 
7۳ اساسيات لينكس 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 


Especially for those who master it. 


تنفیذ الأمر 0 


£4 رار۹ الخطوة‎ ٤٠ 


أدخل النص التالي: 


This line added by pressing lowercase ۰ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 
It is a very powerful text editor. 


This line was added by pressing lowercase o. Especially for those who m 
aster it. 


١٤ الخطوة‎ ١ 


الخروج من وضع الادراج عن طريق الضغط على مفتاح هروب „Esc‏ 


> ESC > 


اساسیات لینکس 


47 الخطوة‎ ٢ 


انشاء سطر فارغ فوق السطر الحالي عن طریق الضغط علی الحرف الکبیر 0: 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 


This line was added by pressing lowercase o. 


Especially for those who master it. 


£Y الخطوة‎ ۳ 


آدخل النص التالي: 


You just pressed 010 open a line above. 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


اساسیات لینکس 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 


You just pressed O to open a line above. 


This line was added by pressing lowercase o. 


Especially for those who master it. 


ء Y,‏ الخطوة ££ 


الخروج من وضع الادراج عن طريق الضغط على مفتاح خروج. 


£o الخطوة‎ ٤٥ 


احفظ الملف واغلق المحرر vi editor‏ باستخدام أي من الطرق التالية والتي تحفظ التغييرات: 


الأمر الوظیفة/ المفتاح 

34 حفظ وإغلاق الملف. 

wq‏ للكتابة على ملف والخروج. 

wq!‏ للكتابة على ملف للقراءة فقط إذا کان ذلك ممكنا والخروج. 
7 حفظ واغلاق. لاحظ أنه Y‏ يتم استخدام نقطتين : في هذه الحالة. 
:q!‏ الخروج من غير حفظ 

:e!‏ تجاهل التغیرات واعادة تحمیل الملف. 

۷۷۱: للكتابة على ملف للقراءة فقط اذا کان ذلك ممكنا. 


جدول یصف آوامر لاغلاق المحرر 


اساسیات لینکس 


٤٤ الخطوة‎ 7 


مرة أخرى قم بفتح myfile‏ باستخدام المحرر editor‏ ألا: 


£V الخطوة‎ ۷ 


انتقل إلى السطر الثالثء ثم احذف السطر الثالث والرابع: 


36 


0 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 


Bspecially for those who master it. 


2dd 3G تنفيذ الأمرين‎ 


EA الخطوة‎ ٨ 


اضغط على مفتاح Esc‏ للتأكد أنك في وضع الأوامر. 


> ESC > 


٩٤ الخطوة‎ ۹ 


قم بانهاء محرر |۷ دون حفظ التغييرات: 


IL 


QU 
VISION A_J و‎ 

i ul c TVA 
2:2150 یسپ اساسیات لینکس‎ 


۰ الخطوة ٠ه‏ 


ivi مع المحرر‎ myfile cala! افتح‎ 


vi 6 


لاحظ أن الأسطر ” و ٤‏ لا تزال موجودة. 


۱ الخطوة ١ه‏ 


ابحث عن الكلمة line‏ ستلاحظ تحرك المؤشر إلى بداية كلمة ۴6 کما هو مبین في الصورة دناه 


Aline 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


AN‏ اساسيات لينكس 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 


You just pressed O to open a line above. 


This line was added by pressing lowercase o. 


Especially for those who master it. 


تنفیذ الأمر line‏ 


١٥ الخطوة‎ ٢ 


البحث عن النتيجة التالية لكلمة line‏ عن طريق الضغط على حرف n‏ 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


۳۳۹ 


AN‏ اساسيات لينكس 


Hello and welcome to the vi editor. 
It is a very powerful text editor. 


You just pressed O to open a line above. 


106016 [ine was added by pressing lowercase o. 


Especially for those who master it. 


oY $5làll 4, Y,oY 


ابحث عن النتيجة السابقة لكلمة „line‏ ستلاحظ تحرك المؤشر إلى بداية التشابه السابق لكلمة line‏ كما بظهر 


دناه" 


706 


YYY 


A‏ اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 


You just pressed O to open a [ine above. 


This line was added by pressing lowercase o. 


Especially for those who master it. 


تنفیذ الأمر ?line‏ 


٥٥ الخطوة‎ 5٤ 


ابحث عن التشابه السابق لكلمة line‏ عن طريق الضغط على حرف ٦‏ . وبما أنه لا يوجد تطابق في هذا الاتجاه 


الخلفي فان المحرر ۷ سوف يلتف حول الوثيقة: 


YYA 


اساسیات لینکس 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 
It is a very powerful text editor. 


You just pressed O to open a line above. 


This [ine was added by pressing lowercase o. 


Especially for those who master it. 


search hit TOP, continuing at BOTTOM 


تنفیذ الأمر n‏ 


٥‏ الخطو: هه 


ains‏ استبدال كلمة line‏ مع كلمة entry‏ عند الضغط على cw‏ فان كلمة line‏ التي عليها المؤشر سوف 


۳۳۹ 


اساسیات لینکس 


CW 


entry 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


Hello and welcome to the vi editor. 
It is a very powerful text editor. 


You just pressed 0 to open a line above. 


This entrylluas added by pressing lowercase o. 


Especially for those who master it. 


تنفیذ الأمرين ۰6۷۷ entry‏ 


٦‏ الخطوة كه 


اضغط على مفتاح ESC‏ للخروج من وضع الادراج. 


> ESC < 


٥۷ الخطوة‎ ۷ 


أضف نص في بداية السطر. أدخل إلى وضع الإدراج مرة أخرى وأضف سطر عن طريق الضغط على الحرف 


الكبير من jb‏ 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


Yre 


اساسیات لینکس 


Hello and welcome to the vi editor. 
It is a very powerful text editor. 


You just pressed O to open a line above. 


anis entry was added by pressing lowercase o. 


Especially for those who master it. 


I الأمر‎ ian 


ويتشمل وضع الادراج على: «A «a «I. d‏ 0» و ©. 


۸ الخطوة ۵۸ 


اضغط على مفتاح Esc‏ للعودة إلى وضع الأوامر. 


> ESC > 


٩٥ الخطوة‎ ۹ 


أضف نص في نهاية السطر (الحرف الكبير ۸). آولا تحرك إلى السطر الثاني واضف عبارة في :Indeed!‏ 


2G 


[Space]Indeed! 


اضغط على مفتاح Esc‏ للعودة إلى وضع الأوامر. 


> ESC > 


TFA 


اساسیات لینکس 


الشاشة يجب أن تشبه ما يلي: 


Hello and welcome to the vi editor. 


It is a very powerful text editor. 2281 


You just pressed 0 to open a line above. 
This entry was added by pressing lowercase o. 


Especially for those who master it. 


تنفیذ الأوامر 26ء [Space]Indeed! «A‏ 
و دوا لخطوة ٠‏ 


حفظ التغييرات والخروج من المحرر ۷: 


۳ برمجة القشرة الأساسیة 
برمجة القشرة تسمح بأخذ سلسلة معقدة من الأوامر ووضعھا في ملف ثم القیام بتشغيل ذلك الملف کبرنامج؛ مما 
يوفر الكثير من الوقت لعدم الحاجة لكتابة سلاسل طويلة من الأوامر المستخدمة بشكل روتيني. 


سوف يركز هذا التمرين على كيفية إنشاء برنامج نصي بسيط للقشرة «simple shell scripts‏ لاتمام ذلك 
فمن المفتر a‏ أن تعرف كيفية | ï‏ ستخدام محرر | لنصو ص لا تتردد في اختیار محرر مثل: gedit «nano «vi‏ 


أو أي محرر آخر تریده. 


۳۳۲ 


Sv. 
اساسيات لینکس‎ ES 


١ الخطوۃ‎ ۹ 


لإنشاء برنامج نصي : بسيط للقشرة» تحتاج إلى انشاء ملف نصي وإضافة أوامر عليه. قم بإنشاء ملف يسمي 


sample.sh‏ ; واضف الأسطر التالية: 


vi 7 


echo "Hello there! Here is the calendar for this month:" 


cal 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


echo "Hello there! Here is the calendar for this month:" 


cal 


cal «echo "Hello there! Here is the calendar for this month:" تنفیذ‎ 


Y الخطوة‎ 4, Y, Y 


للتوضيح» هذا برنامج نصي لقشرة الباش BASH shell script‏ تحتاج إلى تضمين سطر خاص في الجزء 
العلوي من ملف يسمى "shbang"‏ (أو (shebang‏ يبدأ هذا السطر مع !#" ثم يحتوي على المسار إلى قشرة 


الباش القابلة للتنفيذ. أضف السطر التالي في أعلى الملف :sample.sh‏ 
«ESC-2‏ 
ثم بعد ذلك قم بکتابة التالي: 


۳۳۳ 


اساسیات لینکس 


1G 


147 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


#!/bin/basi 


echo "Hello there! Here is the calendar for this month:" 


cal 


تنفيذ الأمر #!/bin/bash‏ 


Y الخطوة‎ ۳ 


إحدى الطرق التي يمكنك بها تشغيل هذا البرنامج هي عن طریق کتابة باش bash‏ قبل اسم الملف. نفذ ما يلي 


لتنفیذ البرنامج: 


<ESC> 


<Enter> 


bash sample.sh 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


۳۳ 


اساسیات لینکس 


:~$ bash sample.sh 


Hello there! Here is the calendar for this month: 
April 2016 
Su Mo Mu We Ma ze Sa 
d 2 
9 © 
10 11 12 15 ۶ 
11 Te 19 20 21 22 23 


24 25 26 27 22 29 0 


bash sample.sh تنفيذ الأمر‎ 


٤ الخطوة‎ ٤ 


3 كنك تجنب الحاجة إلى کتابة باش bash‏ آمام اسم الملف عن طريق جعل الملف قابل للتنفید executable‏ 
لجمیع المستخدمين. اکتب الأوامر التالية: 

-L sample.sh‏ کا 

chmod ٢۸ 7 

-L sample.sh‏ کا 


Jsample.sh 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


اساسیات لینکس 


5 وا‎ -l sample.sh 


-rw-rw-r-- 1 sysadmin sysadmin 73 Apr 9 22:44 sample.sh 


$ chmod atx sample.sh 
$ ./sample.sh 
Hello there! Here is the calendar for this month: 
April 2016 


Su Mo Tu We Th Fr 


59 ها 1 
22 21 20 19 19 
29 29 27 26 25 


Jsample.sh «ls -L sample.sh «chmod a«x sample.sh «ls -L sample.sh تنفيذ الأوامر‎ 


تم استخدام الأمر chmod‏ لتغییر الأذونات على الملف بحيث يمكن تنفیذ الملف (ستتعلم المزيد عن هذا الامر 


في معامل لاحقة). 


۰( الخطوة ه 


وثمة سمة مشتركة تستخدم في البرمجة هي "backquoting"‏ ومع هذه التقنية؛ يمكنك تشغيل أمر القشرة داخل 
قشرة أخرى. حيث سيتم إرجاع تنفيذ الأمر الداخلي كمعطيات argument‏ لأمر خارجي. أضف ما يلي إلى 


أسفل الملف :sample.sh‏ 


۷ 7 


ثم بعد ذلك أضف التالي: 


۳۳۹ 


اساسیات لینکس 


306 
0 


echo "Today is" 'date +۸۸۰ 


ٹم بعد ذلك قم بالخروج من وضع الادراج: 


<ESC> 


وأخيرا قم بحفظ عملك والخروج من محرر النصوص: 


والان نفذ التالي لعرض محتويات الملف ثم تشغيله: 


cat sample.sh 


وينبغي أن يكون التنفیذ كالتالي: 


225 cat sample.sh 


f!/bin/bash 

echo "Hello there! Here is the calendar for this month:" 
cal 

echo "Today is" "date -*$A' 


:-5 


قم بتشغيل برنامج sample.sh‏ كالتالي: 


Jsample.sh 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


YYY 


7 اساسیات لینکس 


sysadminGlocalhost:-$ . . طو‎ 


Hello there! Here is the calendar for this month: 
April 2016 


Su Mo Tu We Th Fr 


13. 14 3.9 
20) 21 22 
270 28 29 


Today is Friday 


sysadminGlocalhost: ^$ 


Jsample.sh «cat sample.sh «echo "Today is" 0816 +9۵۸ الأوامر‎ 3x 


٦ الخطوة‎ ٦ 


لقد تم استخدام /. أمام اسم الملف sample.sh‏ للاشارة إلى أن الملف موجود في الدليل الحالي. نفذ ما يلي لترى 


كيف سوف تفشل القشرة في العثور على الملف إذا كنت لا تستخدم الرموز D‏ 


sample.sh 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


sysadminGlocalhost:-$ sample.sh 


-bash: sample.sh: command not found 


sysadminélocalhost: : ٭۔‎ 


تنفیذ الأمر sample.sh‏ 


YYA 


اساسیات لینکس 


۷ الخطوة ۷ 


تذكر أن المتغير SPATH‏ يستخدم للبحث عن الاوامر التي كتبتها. نفذ ما يلي لروية المتغیر $PATH‏ لحساب 


:sysadmin 


echo $PATH 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


echo $PATH‏ وہ 


/home/sysadmin/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/s 


bin:/bin:/usr/games 


و : 


echo $PATH تنفیذ الأمر‎ 


۸ الخطوة ۸ 


لاحظ أن /home/sysadmin/bin‏ هو واحد من الدلائل في المتغير .SPATH‏ وهو مكان ممتاز لوضع 


ua paill‏ القشر ة الخاص بلك: 


mkdir bin 


mv sample.sh bin 


sample.sh 


۳۳۹ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


sysadminGlocalhost:-$ mkdir bin 

sysadminGlocalhost:-$ mv sample.sh bin 

sysadminGlocalhost:-$ sample.sh 

Hello there! Here is the calendar for this month: 
April 2016 


Su Mo Tu We Th Fr 


10 33 9 
17 18 19 


24 25 26 


Today is Friday 


sysadminGlocalhost: 


sample.sh «mv sample.sh bin «mkdir bin »4 sy! تنفیذ‎ 


٩, ٤‏ التنفیذ المشروط والمتکرر 


لاحظ أن الامثلة examples‏ التي ستعرض demonstrated‏ في هذا القسم أكثر تعقيداً .more complex‏ 
استخدم تقنية technique‏ أو اسلوب لوصف describe‏ ما يحدث في البرنامج program‏ وسیکون هذا 


الاسلوب مشابه لما يلي: 


٢. 


کہ اساسیات لینکس 


أدخل هذا العامود إلى drive.sh‏ | یصف هذا العامود الكود (لن یدخل في الملف) 
0 "الرجاء إدخال عمرك" # طباعة الموجه 


قراءة العمر # قراءة إدخال المستخدم ومكان المتغير 88096 


جدول لما يحدث في البرنامج السابق 


عند اتباع الارشادات المقدمة instructions provided‏ فأنت الآن تقوم بإدخال النص enter text‏ من 
العامود الأيمن right column‏ في الملف المحدد drive.sh)‏ في المثال أعلاه). أما العامود الأيسر left‏ 
column‏ فهو يستخدم لوصف describe‏ أسطر البرنامج program lines‏ یتم استخدام علامة الشبكة 
(#) لأنه في البرمجة النصية للقشرة shell script‏ يمكنك وضع تعلیقات comments‏ ضمن البرنامج 


7 باستخدام علامة #. 


۱ الخطوة‎ ٩,4۱ 


البرامج النصية Scripts‏ المركبة complex‏ یمکن ان یکون فیها تنفیذ شرطي conditional execution‏ 
التنفیذ الشرطي مثل جملة إذا الشرطية df statement‏ ویمکن الاستفادة من نتانج أمر یسمی اختبار lest‏ 
ila‏ الاختبار test statement‏ تقارن compares‏ بين رقمين أو سلسلتین لأشیاء محددة» مثلاً يساوي 


less than من‎ Jil أو‎ equal to 


est وجملة الاختبار‎ if واجعله قابل للتنفيذ لترى كيف تعمل جملة إذا الشرطية‎ (drive.sh) الملف التالي‎ Cul 


أبدأ من خلال وضع ما يلي في الملف :drive.sh‏ 


Y£) 


T 
2030 اساسیات لینکس‎ p: 
یصف ھذا العامود الکود (لن یکتب في الملف)‎ drive.sh آدخل هذا العامود إلى‎ 
بحتوي هذا السطر على المسار إلى قشرة الباش القابلة للتنفید‎ 0 
طباعة الموجه‎ # | echo "Please enter your age" 
$age قراءة ادخال المستخدم وضعه في متغیر‎ # | read age 
فهو صحيح‎ ۱١ اختبر المتغیر 8806 اذا اعاد‎ # | if test $age - 16 
١5 واذا اعاد عدد أقل من‎ | then 
اذا كانت نتيجة الاختبار صحیح‎ à # | echo "You are not old enough to 
drive." 
else 
نفذ اذا كانت نتيجة الاختبار خاطئة‎ # | echo "You can drive!" 
انھاء الجملة‎ # | fi 
جدول یصف برنامج للرخصة‎ 
لانشاء الملف؛ اکتب الامر التالي:‎ 
vi drive.sh 
:[ وللدخول لوضع الادراج؛ اكتب حرف‎ 
i 
ثم بعد ذلك؛ نقوم بكتابة البرنامج:‎ 
۲ 
لله‎ 


[nu 


mi 


لتشغیل هذا الملف؛ نفذ الأوامر التالیة: 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


اساسیات لینگس 230 


7/0/0 

echo "Please enter your age" 

read age 

if test $age -lt 16 

then 

echo "You are not old enough to drive." 
else 

echo "You can drive!" 

fi 


<ESC> 


<Enter> 


cat drive.sh 
chmod a+x drive.sh 


./drive.sh 


IL 
ده‎ | 


AS‏ اساسيات لينكس 


sysadminGlocalhost:-$ cat drive.sh 
f!/bin/bash 
echo "Please enter your age" 
read age 
if test $age -lt 16 
then 
echo "You are not old enough to drive." 
else 
echo "You can drive!" 


E 


sysadmin@localhost:~$ chmod a*x drive.sh 


sysadminGlocalhost:-$ ./drive.sh 
Please enter your age 

14 

You are not old enough to drive. 


sysadminGlocalhost: ^$ 


Jdrive.sh «chmod 3+× drive.sh «cat drive.sh تنفيذ الأوامر‎ 


تستطیع قراءة الجملة إذا الشرطية وهي "إذا کان العمر هوه أقل من 5١عاماء‏ أظهر رسالة انت لست بالعمر 


الكافي للقيادة؛ والا آظهر الرسالة يمكنك قیادة". والرمز fj‏ يُنهي جملة إذا الشرطية. 


ملاحظة: 06و8 يجب أن يكون قيمة عددية. إذا لم يكن کذلكء سوف یتعطل البرنامج. 


Y الخطوة‎ ۲٢ 


جملة الاختبار ستدعی تلقائيا عند وضع معطیات arguments‏ بين قوسين معقوفين ([ ]) ويحيط بتلك 


المعطیات مسافة بينها وبين الأقواس. عدل جملة إذا في الملف drive.sh‏ بحیث تبدو كما يلي: 


Ir 


0 


اعد تشغيل البرنامج مرة اخرى: 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


IL 
ده‎ | 


اساسيات لينكس مو 


vi ۷٣۳ 
4G 
dd 
0 
if ] 5306 -lt 16 ] 
«ESC- 
3 
«Enter» 
cat drive.sh 
| 
| 
| 


.Jdrive.sh 


fo 


اساسیات لینکس 


sysadminGlocalhost:-$ cat 17 
f!/bin/bash 
echo "Please enter your age" 
read age 
if [ $age -lt 16 ] 
enen 
echo "You are not old enough to drive." 
else 
echo "You can drive!" 


fi 


sysadminllocalhost:~$ ./drive.sh 


Please enter your age 
21 
You cam 1 


sysadminllocalhost:~$ 


./drive.sh «cat drive.sh «if ] $age -lt 16 1 تنفيذ الأوامر‎ 


للاطلاع على القائمة كاملة لجملة الاختبارء شغل الأمر .man test‏ 


هام: يجب أن يكون هناك مسافات حول الأقواس المربعة. فمثلاً الكتابة بهذا الشكل 161 [$age -lt‏ سروف 


تفشل» ولكن عند ترك مسافة بهذه الطرقية [ 16 -lt‏ 5306 ] فان الجملة ستعمل. 


Y الخطوة‎ ٣ 


یمکنك Laj‏ استخدام نتائج أوامر قشرة أخرى لإرجاع نتيجة بالنجاح أو بالفشل. على سبيل المثال أنشأ وشغل 
البرنامج التالي» والذي يستخدم لتحديد ما إذا كان حساب المستخدم موجود على هذا النظام أو لا. أضف ما يلي 


إلى الملف :check.sh‏ 


[nu 


0 


غير الاذونات بالأمر التالي: 


الآن؛ شغل البرنامج عن طريق الأوامر التالية: 


اساسیات لینکس 2030 


vi chech.sh 


st/bin/bash 

echo "Enter a username to check: " 
read name 

if grep $name /etc/passwd » /dev/null 
then 

echo "$name is on this system" 
else 

echo "$name does not exist" 

fi 

«ESC- 

X 

«Enter» 


cat chech.sh 


chmod a+x check.sh 


yéy 


IL 
ده‎ | 


A‏ اساسیات لینکس 


./check.sh 
root 
./check.sh 


bobby 


عند السوال للحصول على اسم المستخدم» اعطي اسم root‏ نفذ الأمر (/check.sh)‏ مرة آخری وأعطي اسم 


bobby‏ الشاشة يجب أن تبدو كما يلي: 


sysadmin@localhost:~$ cat check.sh 
#!/bin/bash 
exo "Ite a 1027871282 EO Checks ۷ 
read name 
if grep $name /etc/passwd » /dev/null 
then 

echo "$name is on this system" 
else 

echo "$name does not exist" 


irat 


sysadminGlocalhost:-$ chmod a*x check.sh 


sysadminGlocalhost:-$ ./check.sh 
Tarer a 10122127212 EO Checks 

15 

root is on this system 
sysadminGlocalhost:-«$ ./check.sh 
Haee ci Username EO ) ۹5 
bobby 


bobby does not exist 
sysadminGlocalhost: ^$ 


تنفیذ البرنامج السابق 


٢٨ 


E We 
اساسیات لینکس‎ AW 


٤ الخطوة‎ 5 


جملة شرطية أخرى وهي حلقة while loop his‏ تستخدم هذه الجلمة لتنفيذ التعليمات البرمجية بشكل متكرر 


طالما يرجع الشرط بنتيجة صحيحة. أبدأ من خلال كتابة ما يلي في الملف المسمى :num.sh‏ 


أدخل التالي إلى num.sh‏ | يصف هذا العامود الكود (لن يُكتب في الملف) 
177 
echo "Please enter a number greater‏ 
than 100"‏ 
read num‏ 
while ] $num -le 100 [‏ | # تنفیذ التعلیمات البرمجية من do"‏ " إلى "نفد إذا 
Do‏ | حالة الاختبار حقیقیة 
echo "$num is NOT greater‏ 
than 100."‏ 
echo "Please enter a number greater‏ 
than 100"‏ 
read num‏ 
done‏ # نھایة جملة الشرط 
$num is greater than «echo ۸۷‏ 


100" 


جدول یصف أوامر حلقة loop‏ 


عند السؤال للحصول على رقم أدخل الرقم Yo‏ وعند السوال في المرة التالية أدخل الرقم ۹۹. وأخيرا آدخل ۱۰۱ 
عند المطالبة للحصول على رقم للمرة الثالثة. 


ادخل البرنامج التالي في الملف :num.sh‏ 


الآنء قم بادخال الأرقام التالية: 


اساسیات لینکس 2030 


vi num.sh 


st/bin/bash 

echo "Please enter a number greater than 100" 
read num 

while ] $num -le 100 [ 

do 

echo "$num is NOT greater than 100." 

echo "Please enter a number greater than 100." 
read num 

done 

echo "Finally, $num is greater than 100" 
<ESC> 

24 

«Enter» 

cat num.sh 

chmod a+x num.sh 


./num.sh 


IL 
ده‎ | 


AN‏ اساسيات لينكس 


25 
99 


101 


الشاشة يجب أن تبدو كما يلي: 


sysadminGlocalhost:-«$ cat num.sh 

f!/bin/bash 

echo "Please enter a number greater than 100" 

read num 

while [ $num -le 100 ] 

do 
echo "$num is NOT greater than 100." 
echo "Please enter a number greater than 100." 
read num 

done 

echo "Finally, $num is greater than 100" 

sysadminGlocalhost:-$ chmod a*x num.sh 


sysadminGlocalhost:-$ ./num.sh 


Please enter a number greater than 100 
25 


25 is NOT greater than 100. 


Please enter a number greater than 100. 


99 


99 is NOT greater than 100. 


Please enter a number greater than 100. 


11 
Finally, 101 is greater than 0 


sysadminGlocalhost: ^$ 


تنفیذ برنامج loop‏ 


Yo) 


التنفيذ مرة أخرى للجملة بین 00 و .done‏ 
وبالتالي سيستمر التكرار حتی ترجع النتيجة خاطئة أو عندما تکون القيمة أكبر من ۱۰۰. 
٥‏ الخطوة ٥‏ 


البرمجية النصية Scripting code‏ هي جزء من قشرة الباش BASH shell‏ مما يعني أنه یمکنك استخدام 
هذه الجمل statements‏ في سطر الأوامر command line‏ مثل ما كنت تستخدمها في المحرر yi‏ الخاص 
بالقشرة. عملية البرمجة النصية مفيدة جداً لجمل مثل (for Alas‏ التي من شأنها اسناد assign‏ قائمة من القيم 
list of values‏ في وقت واحد إلى متغير variable‏ والذي من شأنه إجراء مجموعة من العملیات a set‏ 


of operations‏ على كل قيمة value‏ من تلك القيم. على سبيل المثالء اكتب الأوامر التالية: 


for name in /etc/passwd /etc/hosts /etc/group 
do 
wc $name 


done 


z -" 
S 

3ت | یئ Sl‏ 3 

230 ساسیات لینکس‎ ANS 

إذا رجعت قيمة الشرط صحیحة للجملة ) [ 100 $num -le‏ ] ) فسيتم عندها تنفيذ الجملة بین do‏ و .done‏ 

بمجرد الانتھاء من تنفيذ تلك الجمل» یتم فحص جملة الشرط من جديد. إذا كانت النتيجة صحيحة مرة آخری» يتم 

وينبغي أن يكون التنفيذ مشابه لما يلي: 


اساسیات لینکس 


:~$ for name in /etc/passwd /etc/hosts /etc/group 


> wc $name 

> done 
24 30 1001 /etc/passwd 
7 15 161 58 


46 46 561 7 SEOUD 


و : 


تنفیذ جملة for‏ 


لاحظ أن الأمر ۷۷6 تم تشغیله ثلاث مرات: مرة مع /etc/passwd‏ ومرة مع letc/hosts‏ ومرة أخيرة مع 


Jetc/group 


٦ الخطوة‎ 7 


غالبا ما یتم استخدام الأمر seq‏ بالتعاون مع جملة for‏ حيث أن الأمر 560 يمكن ان يولد قائمة من قيم الاعداد 

الصحیحة على سبيل المثال من ۱ إلى ۱۰. SU‏ قم بتنفيذ البرنامج التالي في سطر الأوامر لانشاء ۱۲ ملف 
تبدأ اسماؤها بالاسم 16511 16512 16513 وتنتهي بالاسم 169112: 

5 

for num in 'seq 1 12 

do 

touch test$num 

done 


ls 


اساسیات لینکس 


ويكون التنفیذ كالتالي: 


3 ror mum 17 eeg 1 12^ 


> touch 0٣٦ 


< done 


5 ls 
169110 test2 69] 8 
testll ج8٤3‎ testo 9 
169112 test4 test? 


seq às تنفيذ‎ 


ot 


l 1 
D 7 g [d FS 
ھن عفد بس‎ e چا‎ 


المعمل العاشر - فهم عتاد الحاسب 


Understanding Computer Hardware 


E 
n ——————————í——X———!]'/ —— J———'JÁJ"J——————————————ÀÀÀ—————————————————————A»——)——s—— | 


20530 اساسیات لینکس‎ ES 
مقدمة‎ ۱۰۱ 


هذا هو المعمل العاشر: فهم عتاد الحاسب .Computer Hardware‏ في هذا المعمل سیتم شرح أوامر تعرض 


مات ye‏ نات جھاز الحاسب الالی. 
عن ر T‏ 


ه استخدم الأوامر لعرض قائمة العتاد. 
۱۰,۲ قائمة عتاد الحاسب 


في هذه المهمة» سوف نقوم بتنفيذ execute‏ بعض الأوامر commands‏ ودراسة بعض الملفات files‏ وذلك 


لعرض display‏ تكوين الأجهزة hardware configuration‏ في الجھاز الذي تعمل عليه. 
۹4 الخطوة Y‏ 
نفذ الأمر من أجل تحدید نوع وحدة المعالجة المركزية: 


lscpu 


وينبغي أن يكون التنفیذ مشابه لما يلي: 


ساسیات لینکس 


sysadminGlocalhost:^$ lscpu 


x86 64 
32-bit, 64-bit 


Little Endian 


GenuineIntel 


1412.265 

4001.62 
VT-x 

32K 

32K 

256K 


15360K 


Architecture: 


CPU op-mode (s): 


Byte Order: 
CPUTS)- 


On-line CPU (s) 


Thread(s) per core: 


Core(s) per socket: 


Socket (s): 
NUMA node(s): 
Vendor ID: 
CPU family: 
Model: 
Stepping: 

CPU MHZ: 
80900: 
Virtualization: 
Lid cache: 
Lli cache: 

L2 cache: 


L3 cache: 


NUMA ۴6۵060 CPU(s): 055, هل‎ 
NUMA ۲60061 CPU(s): 6-11,18-23 


sysadminélocalhost: >5 


تنفیذ الأمر lscpu‏ 


yoy 


عند محاولة تحدید determine‏ مدى إمكانية الاستفادة من مميزات لينكس المتقدمة advanced Linux‏ 
6 وذلك بغرض استخدامها used‏ على نظامك system‏ لمزيد من التفاصيل details‏ حول وحدة 
المعالجة المركزية الخاصة بك CPU(s)‏ يمكنك فحص examine‏ الملف المسمی /proc/cpuinfOo‏ ؛ وتحدیداً 
الأعلام flags‏ والتي یتم سردها listed‏ لروية تفاصيل وحدة المعالجة المركزية الخاصة بك وبالتالي معرفة 


هل توجد مميزات آولا. 
3 القخطوع ۲ 
عرض ملف Jproc/cpuinfo‏ 


cat /proc/cpuinfo 


وينبغي أن يكون التنفیذ مشابه لما يلي: 


1 
5 We 
2:2150 اساسیات لینکس‎ E 


ان عرض display‏ معلومات عن وحدة المعالجة المركزية Central Processing Unit - (CPU)‏ مهم 


Ag 
اساسیات لینکس‎ AS 


sysadminGlocalhost:-$ cat /proc/cpuinfo 
physical id 90 


siblings EU 
core id 

cpu cores 

apicid 

initial apicid 

fpu 

fpu exception 

cpuid level 3ء‎ 
wp : yes 


flags : fpu vme de pse tsc msr pae mce cx8 apic sep mtrr 

pge mca cmov pat pse36 clflush dts acpi mmx fxsr sse sse2 ss ht tm pbe 
syscall nx pdpelgb rdt 

sop lm constant _ tsc arch perfmon pebs bts rep good nopl xtopology nons 

top tsc ap 

erfmperf eagerfpu pni pclmulgdq dtes64 monitor ds cpl vmx smx est 2 


Ssse3 cx16 xtpr pdcm pcid dca sse4 1 sse4 2 x2apic popont tsc deadlin 
e timer aes xsave avx lahf ln epb tpr shadow vnmi flexpriority ept vpi 
d xsaveopt dtherm arat pln pts 

bugs E 


bogomips : 4001.57 

clflush size : 64 

cache alignment : 64 

address sizes : 46 bits physical, 48 bits virtual 
power management: 


sysadminélocalhost: و‎ 


cat /proc/cpuinfo تنفیذ الأمر‎ 


yoq 


اساسیات لینکس 


٣ له‎ 7٣۳ 


لإكتشاف مقدار ذاكرة الوصول العشوائي RAM‏ ومساحة التبادل swap space‏ المستخدمه في جهازك. 
استخدم الامر free‏ 
free -m‏ 
free -g‏ 
عند استخدام الخیار -m‏ مع الأمر free‏ فسیتم اظهار مقدار الذاكرة بالمیغا بایت Ul tmegabytes‏ في ila‏ 
استخدام الخيار -g‏ فسيتم عرض حجم الذاكرة بالغيغابايت „gigabytes‏ 


وينبغي ان يكون التنفيذ كما يلي: 


:~$ free -m 


total used free shared buffers cached 


64394 35057 29337 0 1100 2631 


/* buffers/cache: 


Swap: 


shared buffers cached 


0 1 2 


/* buffers/cache: 


Swap: 


free - «free m تنفيذ الأمرين‎ 


AT 


و اساسیات لینکس 2030 


في التنفيذ أعلاه» يمكنك أن ترى أن النظام system‏ لديه ۱۰۰۶٩‏ ميغا بايت (ما یقرب من ٥١‏ غيغابايت) من 
الذاكرة الفعلية (RAM) physical memory‏ المستخدم used‏ منها فقط ۱۰٦٦‏ ميغا بايت» وهو مؤشر 
good sign +>‏ أن لديك ذاكرة کافیة enough‏ لاحتياجات النظام system's needs‏ الخاص بك في 


الوقت الحالي. 


في حال نفاد الذاكرة ex srun out‏ استخدام التبادل. تقنية التبادل Swap‏ تعني اخذ مساحة Space‏ من القرص 
الصلب hard drive‏ واستخدامها مؤقتا لتخزين البیانات temporarily store data‏ التي من المفترض أن 


تكون مخزنة stored.‏ في ذاكرة الوصول العشواني .RAM‏ 
٤‏ الخطوة ٤‏ 


لمعرفة examine‏ ما هي الأجهزة devices‏ المتصلة connected‏ بناقل PCI bus‏ ء استخدم الأمر 


التالي )6 م5): 
lspci‏ 


لاحظ في التنفيذ الجزئي partial output‏ أدناه؛ أن العدید من الأجهزة many devices‏ متصلة 


0 بلرحة النظام «system board‏ كما هو معروض: 


اساسیات لینکس 


sysadminélocalhost:-$ lspci 


00:00.0 Host bridge: Intel Corporation Xeon E5/Core i7 DMI2 (rev 07) 


00:01.0 PCI bridge: Intel Corporation Xeon E5/Core i7 IIO PCI Express 
Root Port 12 (rev 07) 


00:01.1 PCI bridge: Intel Corporation Xeon E5/Core i7 IIO PCI Express 
Root Port 1b (rev 07) 


00:02.0 PCI bridge: Intel Corporation Xeon E5/Core i7 IIO PCI Express 
Root Port 2a (rev 07) 


00:03.0 PCI bridge: Intel Corporation Xeon E5/Core i7 IIO PCI Express 
Root Port 


3a in PCI Express Mode (rev 07) 


00:04.0 System peripheral: Intel Corporation E5/Core 
Channel 0 (rev 07) 


00:04.1 System peripheral: Intel Corporation E5/Core 
Channel 1 (rev 07) 


00:04.2 System peripheral: Intel Corporation E5/Core 
Channel 2 (rev 07) 


00:04.3 System peripheral: Intel Corporation E5/Core 
Channel 3 (rev 07 


00:04.4 System peripheral: Intel Corporation E5/Core 
Channel 4 (rev 07) 


00:04.5 System peripheral: Intel Corporation E5/Core 
Channel 5 (rev 07) 


تنفيذ الأمر lspci‏ 


نتائج الأمر lspci‏ هامة لتحديد الأجهزة التي لا تدعمها نواة لينكس. بعض الأجهزة مثل بطاقات الفیدیو video‏ 
65 قد لا توفر سوى الوظائف الأساسية basic functionality‏ إذا لم يتم تثبیت install.‏ برنامج التشغيل 


المناسب لها. 


° الخطوة‎ ٥ 


استخدم الخیار -k‏ مع الأمر lspci‏ لإظهار الأجهزة مع مشغل النواة kernel driver‏ والوحدات المستخدمة: 


YN 


اساسیات لینکس 


lspci -k 


وينبغي ان يكون التنفیذ كما يلي: 
sysadminGlocalhost:^$ lspci -k‏ 
Host bridge: Intel Corporation Xeon E5/Core i7 DMI2 (rev 07)‏ 00:00.0 
Subsystem: Super Micro Computer Inc Device 0626‏ 
PCI bridge: Intel Corporation Xeon E5/Core i7 IIO‏ 00:01.0 
Root Port‏ 
la (rev 07)‏ 
Kernel driver in use: pcieport‏ 
PCI bridge: Intel Corporation Xeon E5/Core‏ 00:01.1 
Root Port‏ 
1b (rev 07)‏ 
Kernel driver in use: pcieport‏ 
PCI bridge: Intel Corporation Xeon E5/Core Express‏ 
Port‏ 
)07 
Kernel driver in use: pcieport‏ 
PCI bridge: Intel Corporation Xeon E5/Core Express‏ 00:03.0 
Root Port‏ 
3a in PCI Express Mode (rev 07)‏ 


Kernel driver in use: pcieport 


00:04.0 System peripheral: Intel Corporation Xeon E5/Core i7 DMA 
Channel 0 (rev 07) 


Subsystem: Super Micro Computer Inc Device 0626 


Kernel driver in use: ioatdma 


00:04.1 System peripheral: Intel Corporation Xeon E5/Core i7 DMA 
Channel 1 (rev 07) 


lspci —k تنفیذ الأمر‎ 


٢٣ 


اساسیات لینکس 


٦ الخطوة‎ ٦ 


لسرد قائمة بالأجهزة المتصلة بالنظام عبر المنفذ التسلسلي العالمي ‘Universal Serial Bus - (USB)‏ 


استخدم الامر التالي: 


lsusb 


لاحظ أن الإخراج التالي مختلف؛ حيث لم يتم الکشف عن أي أجهزة USB‏ متصلة بالنظام: 


:-$ lsusb 


unable to initialize libusb: -99 


وم : 


تنفيذ الأمر lsusb‏ لنظام تشغیل افتراضي 


ذلك لأن النظام السابق هو نظام افتراضي tvirtualized‏ وفیه قد لا تظهر أجهزة USB‏ المتصلة بالنظام كما 
يظهر عادة عند تنفيذ الأمر lsusb‏ في الأجهزة العادية. والان؛ سنجرب الأمر السابق في أحد الأنظمة العادية؛ 


وستکون النتيجة فيه كالتالي: 


:~$ lsusb 


Bus 001 Device 001: ID 17121855009077 Linux Foundation 1.1 root hub 


وم : 


تنفيذ الأمر lsusb‏ لنظام تشغیل حقيقي 


HAL‏ هو طبقة العتاد المجردة Hardware Abstraction Layer‏ ( والتي هي عبارة عن مجموعة من 
الاجراءات الروتينية في البرامج التي تحاكي بعض التفاصیل الخاصة بالنظام الأساسيء وبالتالي تسمح لبرامج 
سطح المکتب من اکتشاف موارد الجهاز والوصول الیها). البرنامج الخفي daemon‏ ل HAL‏ هو hald‏ 
(البرنامج الخفي هو الذي يعمل في الخلفية بغیر إدراك من المستخدم العادي)» يقوم hald‏ بتحدیث update‏ 


قاعدة بیانات database‏ عن الأجهزة المتصلة بالنظام connected devices‏ وعند حدوث تغیر بطريقة 


و اساسیات لینکس 2230 


0 هذا الحدث event‏ في الانظمة التي تستخدم HAL‏ فان الأمر Ishal‏ يكون قادر على سرد 


قائمة بالأجهزة devices‏ في ذلك النظام. 
١٠,۷‏ الخطوة V‏ 


نواة لینکس Linux kernel‏ عادة تُحمل برنامج تشغیل driver‏ أو وحدة نمطية module‏ خاصة بالأجهزة 


لتتمكن تلك الاجهزة من القيام بوظائفها. استخدم الأمر lsmod‏ لعرض وحدات يتم تحميلها حاليا: 
lsmod‏ 


الشاشة أدناه هي تنفيذ جزئي partial output‏ ونجد ان العامود الأول هو اسم الوحدة النمطية «module‏ أما 
العامود الثاني فهو مقدار الذاكرة المستخدمة من الوحدة. أما الرقم في العامود الثالث Used by"‏ " فیشیر إلى 
كم عدد الوحدات الأخرى التي تستخدم نفس الوحدة. ويمكن أيضا أن asi‏ أسماء تلك الوحدات في هذا العامود» 


أو بأخرى لحالة state‏ الأجهزة المتصلة؛ فان hald‏ يبث broadcasts‏ هذه المعلومات إلى أي عمليات سجلت 
ولكن غالبا ما تكون تلك الأسماء غير كاملة: 


Ag 
اساسیات لینکس‎ AS 


sysadminélocalhost:-^$ lsmod 

Module Size Used by 

dccp diag 16384 0 

dccp 73728 1 dccp diag 

udp diag 16384 0 

unix diag 16384 0 

tcp diag 16384 0 

inet diag 20480 3 dccp diag,udp diag,tcp diag 
xt nat 16384 457 

veth 16384 0 


vxlan 49152 0 


ip6 udp tunnel 16384 1 vxlan 


udp tunnel 16384 1 vxlan 

ipmi devintf 20480 0 

ib iser 49152 0 

rdma cm 49152 3b iser 

iw cm 45056 rdma cm 

ib cm 45056 rdma cm 

ib sa 36864 rdma cm,ib cm 
ib mad 53248 ib cm,ib sa 


ib core 106496 ib iser,rdma cm,iw cm,ib cm,ib sa,ib 
mad 


تنفیذ الأمر lsmod‏ 


۸ الخطوة ^ 


لوحة النظام system board‏ في العديد من أجهزة الحاسب تحتوي على ما یعرف باسم «BIOS‏ وهو نظام 
الادخال والإخراج الأساسي Basic Input and Output System‏ نظام إدارة 8105 أو 50/8/08 


هو معيار لتحدید standard defining‏ هياكل البيانات data structures‏ وكيفية نقل المعلومات 


۳۹۹ 


2030 07 A 


communicate information‏ عن عتاد الحاسب .computer hardware‏ الأمر dmidecode‏ قادر 
على قراءة وطباعة المعلومات من SMBIOS‏ في العديد من النظم. وهو لن يعمل هناء لأنه لا يعمل بشكل 


صحيح ضمن البيئة الافتر اضیة environment‏ ۷۱۱۲۷۵۱۔ 
الأمر fdisk‏ يمكن استخدامه بطریقتین: بشكل تفاعلي interactively‏ وغير تفاعلي .non-interactively‏ 


عند استخدام الخيار -l‏ مع fdisk‏ سيصبح الأمر غير تفاعلي مع قائمة كتل الأجهزة» والتي تشمل الأقراص 


(الأقراص الصلبة) وحدات التخزین المنطقیة, 


بدون خيار ]- يدخل الأمر fdisk‏ إلى الوضع التفاعلي والذي بستخدم عادة لتعديل الأقسام partitions‏ على 


القرص .disk device‏ 
4 الخ ةة 


نفذ الأمر 0 لسرد أجهزة الأقراص غير التفاعلية على شكل قطاعات tsectors‏ وبدون عرض تحذيرات 


:DOS التوافق‎ 
fdisk -cul 


التنفيذ الجزئي partial output‏ لهذا الأمر يُظهر ثلاثة نتانج» أول قرصین هما /dev/sdb s /dev/sda‏ 
والأقسام الخاصة بهما. أما القرص الثالث والموجود eL‏ 06/506/ فهو وحدات التخزين المنطقية logical‏ 


5 التي تم حذفها «omitte‏ وستری ذلك في التنفيذ التالي: 


ےھ 
AW‏ اساسيات لینکس 


sysadminGlocalhost:-$ fdisk -cul 

Disk /dev/sda: 21.5 GB, 21474836480 bytes 

255 heads, 63 sectors/track, 2610 cylinders 

Units = cylinders of 16065 * 512 = 8225280 bytes 
Sector size (logical/physical): 512 bytes / 512 bytes 
I/O size (minimum/optimal): 512 bytes / 512 bytes 


Disk identifier: 0x000571a2 


Device Boot Blocks Id System 
/dev/sdal 19921920 83 Linux 
/ dev/sda2 1046529 5 Extended 


/dev/sda5 1046528 82 Linux swap / 
Solaris 


sysadminélocalhost: و‎ 


fdisk -cul تنفیذ الأمر‎ 


استخدام الخیار -u‏ مع الأمر fdisk‏ یعرض وحدات التخزين على شكل قطاعات بدلا من اسطوانات. آما الخيار 


.DOS من طباعة تحذیرات التوافق‎ fdisk فیقوم بمنع الأمر‎ -C 


1۸ 


هداي کرت 3 
رس اساسیات لینکس 26 


المعمل الحادي عشر - ادارة الحزم والعملیات 


Managing Packages and 5 


PS‏ اساسیات لينكن 


١‏ مقدمة 


هذا هو المعمل الحادي عشر: ادارة الحزم والعمليات. عن طريق أداء هذا التمرین؛ سوف تتعلم المواقع 
5 التي بها معلومات النواة «kernel information‏ ومعرفة معلومات المعالجة process‏ 
information‏ والمكتبات libraries‏ وملفات ajas «og files Js‏ البرمجیات software‏ 


packages 


o‏ التحقق من كيفية استخدام نظام الملفات /proc‏ من قبل النواة. 

o‏ استخدام الأمر وم لعرض معلومات Adae‏ من العملیات. 

ه تعلم كيفية إدارة العملیات» والتي تشمل البدء» والایقاف والاستئناف. 
e‏ ملفات السجل. 


٭ إدارة امكانية تحميل مكتبات مشتركة. 


۱,۲ النواة و /proc‏ 


في هذه المهمة سوف نستکشف الدلیل /proc‏ والأوامر التي تتصل communicate‏ مع نواة لینکس Linux‏ 
kernel‏ بظهر الدلیل /proc‏ على انه دلیل عادي» /usr di‏ أو /etc‏ ولکن الحقيقة غير ذلك Lus‏ فالدلیل 
6 هو نظام الملفات الصوري أو الغیر حقيقي pseudo filesystem‏ ویتم الاحتفاظ به في ذاكرة الحاسب. 


وذلك عکس الدلیلین /usr‏ أو /etc‏ (والتي عادة ما تکون محفوظة في محرك الاقراص). 


یستطیع الدلیل /proc‏ الوصول الى معلومات كل عملية process‏ قید التشغیل running.‏ على النظام. برامج 
مثل top 5 ps‏ تقوم بقراءة المعلومات حول العملیات processes‏ قيد التشغیل running‏ من خلال الدلیل 
6 وادلته الفرعية. والتي تحتوي على معلومات حول نظام التشغيل والأجهزة الخاصة به مثل 
0 (الخاص بمعلومات المعالج) و /proc/meminfo‏ (الخاص بمعلومات الذاکرة) و 


9 (الخاص بالاجهزة). 


2230 اساسیات لینکس‎ ps 
والذي هو جزء من‎ /proc/Sys على دليل فرعي باسم‎ /proc بالإضافة الى الدلائل الثلاثة السابقة؛ يحتوي‎ 
نواة التشغیل‎ settings اعدادات‎ alter والتي يمكن استخدامها لتغيير‎ pseudo files الملفات الصورية‎ 
editor فانه لا ينبغي أن يُستخدم محرر‎ not real وبما أن هذه الملفات ليست ملفات حقيقية‎ running kernel 
محتویات‎ overwrite (35 للكتابة‎ sysctl أو‎ echo من ذلك يجب استخدام أحد الأمرین‎ Ya لتعدیلها.‎ 
oS, «editor هذه الملفات في محرر‎ view تلك الملفات. وللسبب نفسه فلا تقم بمحاولة عرض‎ 56 
لذلك.‎ sysctl أو‎ cat استخدام الأمر‎ 
تستخدم‎ kernel 3! sil فان‎ «configuration في التکرین‎ permanent changes لعمل تغییرات دائمة‎ 
عندما یکون‎ /proc على ملفات‎ changes والذي يُستخدم عادة لاجراء تغییرات‎ tetc/sysctl.conf/ الملف‎ 
. Starting up النظام في مرحلة التشغیل‎ 

1391 الخطوة ١‏ 
في هذه المهمف» سوف نستعرض بعض الملفات الموجودة في الدليل 0۲06/: 

ls 60‏ 
وينبغي أن يكون التنفيذ مشابه لما يلي: 
۲۷۱ | 


sysrq-trigger 
SySvipc 
thread-self 
timer list 
timer stats 
CEV 

uptime 
version 
version signature 
vmallocinfo 
vmstat 


zoneinfo 


اساسیات لینکس 


100 

7062 

net 
pagetypeinfo 
partitions 
sched debug 
Schedstat 


scsi 


slabinfo 
SOE EE OS 


SEE 


REOG 

kalls yms 
kcore 
key-users 
keys 

kmsg 
kpagecount 
kpageflags 
loadavg 
locks 
mdstat 
meminfo 
MLSE 
modules 


mounts 


sysadminGlocalhost:-$ ls 


cpuinfo 

0 ۱/۵9 
devices 
diskstats 
dma 

driver 
execdomains 
fb 
filesystems 
HS 
interrupts 
iomem 
ioports 


irq 


acpi 
buddyinfo 
bus 
cgroups 
cmdline 


consoles 


sysadminGlocalhost: ^$ 


ls /proc تنفيذ الأمر‎ 


تذكر أن الدلائل directories‏ تحتوي على أرقام تمثل العملیات الجارية running processes‏ على النظام 
on the system‏ العملية الأولى هي دائما /sbin/init‏ وبالتالي فان الدلیل /proc/1‏ سيحتوي ملفات 


dinit بها معلومات حول عملية تشغیل‎ contains files 


ملف cmdline‏ هو ملف داخل دليل المعالجة (علی سبيل المثال (/proc/1/cmdline‏ سوف يُظهر الأوامر 
التي تمت كتابتها وتنفيذها. وهنا يجب أن تلاحظ أن ترتيب العمليات التي تم تشغیلھا يختلف اختلافا كبيرا من نظام 
إلى آخر. وحيث ان محتوى هذا الملف لا يحتوي على حرف سطر جدیدہ سيتم تنفيذ مر echo‏ ليذهب الموجه 


إلى سطر جديد. 
۱۱,۲۲ الخطوة ۲ 
استخدم الأمران 681 ثم ps‏ لعرض معلومات حول عملية /sbin/init‏ (معرف العملية PID‏ هو الرقم ۱): 


VY 


اساسیات لینکس 


cat /proc/1/cmdline; echo 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-5 cat /proc/1/cmdline; echo 


/sbin/init 


cat /proc/1/cmdline; echo تنفیذ الأمر‎ 


ملاحظة: في Qual‏ السابق؛ تم تنفیذ الأمر echo‏ على الفور بعد الأمر cat‏ ولعدم وجود معطيات 


1 فتم وضع موجه الأوامر في سطر جدید. 


ولمعرفة لماذا تم استخدام secho‏ نفذ الأمر cat‏ فقط. وينبغي أن یکون التنفیذ مشابه لما يلي: 


:~$ cat /proc/1l/cmdline 


/sbin/init :-5 


لاحظ أن التنفيذ ظهر في نفس سطر موجه الأوامر؛ بینما استخدام الامر 66110 سيجعله يظهر في سطر جديد. 


والآن؛ نفذ الامر التالي لعرض العمليات قيد التشغيل؛ والخيار م- لتحديد رقم العملية التي نريدها: 


ps -p 1 


وينبغي أن يكون التنفيذ مشابه للتالي: 


:-$ ps -p 1 


2 ۲ TIME CMD 


1 8 010 500300 imir 


تنفیذ الأمر1 م- 05 


الملفات الأخری في الدليل /proc‏ تحتوي على معلومات حول نظام التشغيل .operating system‏ وفي 


المهام التالية سنتعلم عرض وتعدیل هذه الملفات. 


YT 


اساسیات لینکس 


vv‏ ا الخطية+ 


اعرض الملف /proc/cemdline‏ لترى ما هي المعطیات arguments‏ التي تم تمريرها passed‏ للنواة 


:boot time وقت الاقلاع‎ kernel 


cat /proc/cmdline 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


cat 46‏ تید 


BOOT IMAGE-/vmlinuz-4.2.0-34-generic root-/dev/mapper/vlabs--vg-root 
ro cgroup enable- 


memory swapaccount-l 


و : 


cat /proc/cmdline تنفیذ الأمر‎ 


۳ ادارة العمایاث 


في هذه المهمة سوف نقوم ببدأ العملیات و ایقافها. 


١ الفطورة‎ 111 


في النافذة الطرفية terminal‏ اكتب الأمر التالي: 


ping localhost < /dev/null 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


٧٢ 


اساسیات لینکس 


:~$ ping localhost > /dev/null 


ping localhost > /dev/null الأمر‎ 3s 


الأمر ping‏ يقوم باختبار الاتصالء وفي المثال السابق تم إعادة توجیه ping‏ إلى الملف /dev/null‏ (والمعروف 
باسم سلة البت (bit bucket‏ وعلى الرغم من انه ALS‏ للمحذوفات؛ إلا انه وبعد إرسال الأشياء التي لا نريدها 


اليه؛ فإنه يزودنا برقم الوظيفة ومعرف العملية. 


لاحظ أن النافذة الطرفية terminal‏ تبدو عالقة أو متوقفة عن الاستجابة hang up‏ عند التنفيذ السابق. السبب 
في ذلك ان هذا الأمر يعمل في المقدمة foreground‏ وبالتالي سيستمر النظام بتنفيذ الأمر ping‏ حتى يتم إنهاء 


06 العملیة process‏ أو تعطیلها suspended‏ من قبل المستخدم „User‏ 


953 ۹ 


لانهاء Terminate‏ العملیة process‏ التي بالمقدمة foreground‏ بشكل نهائي ولیس colo‏ اضغط على 


ہے ہے ipea‏ 


Ctrl-c 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


:~$ ping localhost > /dev/null 


تنفيذ الضغط على Ctrl-C‏ 


٣ اک‎ ۴۳۴ 


اعد كتابة نفس الامر السابق وقم بجعله يعمل في الخلف background‏ عند طريق وضع علامة 8 كما يلي: 


Vo 


اساسیات لینکس 


ping localhost < /dev/null & 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ ping localhost > /dev/nul 6 


تنفیذ الأمر & ping localhost » /dev/null‏ 
عن طريق إضافة علامة & في نهاية الأمر السابق؛ فسيتم تنفيذ تلك العملية في الخلف «background‏ وبالتالي 
يستمر المستخدم في التحكم والسيطرة على النافذة الطرفية „terminal‏ 


.PID هو معرف العملية السابقة‎ ۱٥۸ أن الرقم‎ bay 


وهناك طريقة لإعادة كتابة الامر السابق وهي الاستفادة من سجل الأوامر history‏ وذلك بالضغط على مفتاح 
سهم لأعلى + على لوحة المفاتیح» ثم إضافة مسافة وعلامة & واخیرا الضغط على مفتاح ادخال «Enter»‏ 


(وهذه الطريقة موفرة للوقت عند ادخال أوامر مشابه). 
لاحظ أن الأمر السابق يقوم بإرجاع المعلومات التالية: 
3058 ۳۳ 
العدد بين الأقواس المربعة [ ] هو رقم الوظيفة job‏ لهذه العملية process‏ أما الرقم الذي يليه فهو معرف 


العملية Process ID (PID)‏ إذاً رقم الوظيفة job number‏ في المثال السابق هو ١ء‏ أما رقم معرف العملية 


. 38^ هو‎ PID 


(معلومة: كل نافذة طرفية/ قشرة terminaUshell‏ سوف يكون لها رقم وظيفة فریدء US‏ ان لکل عملية PID‏ 


رقم هوية ID number‏ فريد على نطاق النظام بالکامل). 


هذه المعلومات important iss information‏ عند اجراء تعدیلات manipulations‏ على عملية من 


العملیات» مثل وقف stop‏ العملية أو تغيير changing‏ قيمة الأولوية لها priority value‏ 


٢ 


اساسیات لینکس 


ملاحظة: من المرجح أن يكون معرف العملية في نظامك مختلف عن الأرقام الموجودة هنا. 


ر۹۳١‏ الخطوة £ 


الأمر التالي يستخدم لمعرفة الأوامر تعمل حاليا في النافذة الطرفية :current terminal‏ 


jobs 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


[1]+ Running ping localhost » /dev/null & 


تنفیذ الأمر jobs‏ 


ol Lay‏ الامر ping‏ ما زال قيد التشغيل» e‏ تم استخدامه في هذه الفقرة» عكس امر echo J‏ والذي يؤدي 


عمله ثم ينتهي وتصبح حالته «Done‏ جرب استخدام الأمر cecho Hi < /dev/null%‏ ثم اكتب الأمر jobs‏ 
٥‏ الخطوة ٥‏ 
شغل آمر ping‏ آخر في الخلفية عن طريق كتابة ما يلي: 

ping localhost < /dev/null & 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ ping localhost > /dev/nul 6 


ping localhost » /dev/null & تنفیذ الأمر‎ 


لاحظ أن رقم الوظيفة job number‏ ومعرف العملیة process ID‏ مختلف لهذا الأمر الجدید. 


YYY 


اساسیات لینکس 


٦ الخطوة‎ ٦ 


الان» يجب أن يكون هناك اثنين من أومر ping‏ تعمل في الخلفیة للتحقق من ذلكء اكتب jobs‏ مرة آخری: 


jobs 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Running ping localhost » /dev/null & 


Running ping localhost » /dev/null & 


تنفیذ الأمر jobs‏ 


۷ الخطوة ۷ 


وبمجرد الانتهاء من التحقق من أن اثنين من أوامر ping‏ قيد التشغیل» احضر bring‏ الأمر الأول الى المقدمة 


0 عن طريق كتابة ما يلي: 


fg 961 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ fg 1 


ping localhost » /dev/null 


تنفیذ الأمر 961 fg‏ 


۸ الخطوة ۸ 


لاحظ أن الأمر ping‏ يأخذ السيطرة مرة أخرى على النافذة الطرفية «terminal‏ لایقاف stopped‏ العملية 
(وليس إنهائها) واستعادة السيطرة على النافذة الطرفیة اكتب على :Ctrl-z‏ 


YVA 


اساسیات لینکس 


Ctrl-z 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ fg 1 
ping localhost » /dev/null 


^ 


[1]* Stopped ping localhost » /dev/null 


تنفیذ الأمر Ctrl-z‏ 


٩5 الخط‎ ۹۹ 


لاعادة استکمال continue executing‏ العملية السابقة «previous process‏ وجعلها تعمل في الخلفية 


execute 3 «background‏ الأمر التالي: 
bg 961‏ 
وينبغي أن يكون التنفيذ مشابه لما يلي: 


:-$ bg $1 


[1]* ping localhost » /dev/null & 


تنفیذ الأمر 961 bg‏ 
Ve 5۹ 13‏ 
أكتب الأمر jobs‏ مرة آخری للتحقق من العمليات aë‏ التشغيل running processes‏ 
jobs‏ 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


۳۷۹ 


اساسیات لینکس 


Running ping localhost » /dev/null & 


Running ping localhost » /dev/null & 


تنفیذ الأمر jobs‏ 


۱ الخطوة ۱۱ 


بعد ذلك؛ أكتب أمر ping‏ جديد عن طريق کتابة ما يلي: 
مر ass ping‏ عن طریق كتابة ما يلي 


ping localhost < /dev/null & 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


٠ت‎ ping localhost > /dev/nul 6 


ping localhost » /dev/null & تنفیذ الأمر‎ 


۲ الخطو: ۱۲ 


أكتب الأمر jobs‏ مرة أخرى للتحقق من ان هناك ثلاث three‏ عملیات قید التشغیل Tunning processes‏ 


jobs 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Running ping localhost » /dev/null & 


Running ping localhost » /dev/null & 


Running ping localhost » /dev/null & 


تنفیذ الأمر jobs‏ 


TA. 


اساسیات لینکس 


۱۳ الخطوة‎ ٣۳ 


استعمل رقم الوظيفة job number‏ » لانهاء الأمر ping‏ باستخدام الأمر Kill.‏ ثم بعد ذلك تحقق من الانهاء 
بتنفیذ الأمر jobs‏ 

kill 3 

jobs 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ kill $3 
:~$ jobs 


Running ping localhost » /dev/null & 


Running ping localhost » /dev/null & 


Terminated ping localhost > /dev/null 


jobs «kill 963 تنفیذ الأمرین‎ 


٤١ الخطوة‎ ٤ 


وأخيراًء يمكنك |نهاء كافة الأوامر التي من نوع واحد باستخدام الأمر „killall‏ فمثلاً قم بانهاء جمیع أوامر «ping‏ 


بعد تنفیذ الامر السابق؛ انتظر بضع لحظات ثم قم بتشغيل الأمر jobs‏ للتحقق من أن جمیع العمليات قد أنهيت: 


killall ping 


jobs 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


YAY 


: 
+ 
GY‏ اساسيات لينكس 


:~$ killall ping 


Terminated ping localhost > /dev/null 


Terminated ping localhost > /dev/null 


تنفيذ الأمرین jobs «killall ping‏ 
٤‏ استخدام آمر top‏ لعرض العملیات 


في هذه المهمةء سوف نستخدم الأمر م10 للعمل مع العملیات. افتراضياً؛ يقوم برنامج top‏ بفرز sorts‏ العمليات 
تنازليا descending order‏ وذلك بحسب نسبة الاستخدام بالمعالج .CPU usage‏ وبالتالي فان البرامج 


النشطة والمشغولة busiest programs‏ ستكون في أعلى القائمة. 
١‏ الخطوة ١‏ 
في النافذة الطرفية terminal‏ اكتب الأوامر التالية: 


ping localhost < /dev/null & 


ping localhost < /dev/null &‏ 
وينبغي آن يكون التنفیذ مشابه لما يلي: 


:~$ ping localhost > /dev/nul 6 


:~$ ping localhost > /dev/nul & 


ping localhost » /dev/null & «ping localhost » /dev/null & تنفیذ الأمرین‎ 


YAY 


^N‏ اساسيات لينكس 


اعمل مذكرة لأرقام العمليات IPIDS‏ وذلك لاستخدامها في الخطوات اللاحقة „subsequent steps‏ حيث 


أن ارقام العملیات في نظامك ستكون مختلفة عن الأرقام الموجودة في المنهج. 


cr 2۶‏ 
اكتب الأمر top‏ في النافذة الطرفية terminal‏ 

top 
وينبغي أن يكون التنفيذ مشابه لما يلي:‎ 


Esp - 0056554 wp 77 1 user, load average: 0.09, 0.14, 0.20 
Tasks: 10 total, 1 running, 9 sleeping, 0 stopped, 0 zombie 

1.955۷,  0.05ni, 96۰15104, ۶۶۶ ١+ 7 0۰01 
Mem: 65969788k total, 7629004k used, 58340784k free, 266340k 


buffers 


Swap:  2097148k total, Ok used, 2097148k free, 939076k cached 


NIVIRT TIME 


l 268 2 U 17999 2972 2024 © Q9 ۵ 9801014 اناد‎ 


19 syslog 20 © 11177 27965 2420 $ 9 0.0 0:00.05 rsyslogd 


23 POOL 20 © 19120 2020 11924. $ 9 08 0:00-00 0 
25 TOOL 20 50048 3416 2812 S : 0:00.00 0 
41 bind 20 321/11 LON 15 : 0:00.04 named 
50 root 20 54460 2584 2176 : 0:00.00 login 
62 sysadmin 20 18084 3200 2700 í 0:00.01 08 
sysadmin 20 6504 1824 1688 ; :00.46 ping 
sysadmin 20 6504 1788 6 : :00.40 ping 


sysadmin 20 17212 0 ۵ه)‎ : 300.01 EOS 


YAY 


اساسیات لینکس 


ملاحظة: إخراج الأمر top‏ يتغير changes‏ كل ثانيتين .every 2 seconds‏ 


٣ 8‏ وا 


الأمر top‏ هو برنامج تفاعلي interactive program‏ مما يعني أنه يمكنك إصدار الأوامر داخله. فمثلاً 


سيتم استخدم الأمر top‏ لإنهاء عمليات pings‏ عن طريق كتابة الحرف k‏ 


لاحظ ان الموجه سيظهر أسفل كلمة Swap‏ كما يلي: 


top = 01:52:14 up 29:13, ١٤ user, load average: 0.04, 0.11, 0.19 


772851255 18 total, 1 running, 9 sleeping, 0 stopped, 0 zombie 


Goules 2٣۰260108 ۰ 2 7 0,0 mi. ۶۳ 014۰7 0 0 رل‎ omii Sgn 
s OO SE 


Mem: 65969788k total, 51571885 06381 272225001 رو 6 م۳6‎ ۲ 
buffers 


Swap:  2097148k total, Ok used, 2097148k free, 1110844 cached 
PID to kill: 


MEE‏ دده 


1 35 xou 20 0 17868 2872 2624 S © 0.0 0300-14 imie 


19 syslog 20 0 1717 2796 2420 $ 0 0-0 0:00.07 rsyslogd 

23 TOOL 20 0 19120 2020 1924 $ 0 00 0:00.00 7 

25 ٤ 20 50048 3416 2812 S : 0:00.00 sshd 

41 bind 20 376m Lom 5988 : 0:00.07 named 

50 TOOL 20 54460 2584 6 : 0:00.00 login 

62 sysadmin 20 18084 3200 2700 : ۳۰ ۵۱۵۰1 basim 
sysadmin 20 6504 1824 1688 : 21010 GS 2 
sysadmin 20 6504 1198 19 ; 21010 85 ANO 


sysadmin 20 1172129 2240 8 : 901-898 28 


YA 


34 
^W‏ اساسيات لينكس 


٤ الخطوة‎ 5 


في خانة الموجه والخاصة بالقضاء على العملية PID to kill‏ اكتب رقم العملية (PID)‏ التي تريد انهائهاء وهي 


عملية اختبار الاتصال الأولى ping‏ ذات الرقم ۹۹ء ثم بعد ذلك اضغط على مفتاح Enter‏ 


99 


Enter >‏ > 
لاحظ التغییرات السريعة التي ستحدت في النافذة الطر فية terminal‏ 


top = 0:25:53 up LOL days, 1057 1 user, load average: 1.22, 0.75 
p 0.69 
Tasks: 11 total, 1 running, 10 sleeping, 0 stopped, 0 zombie 


:  1.7$us, 1.859۷,  0.0$ni, 96.1$id, .0.3$wa,  0.0$hi,  0.1$si 
Sst 


Cpu (s) 
po QzQ 


Mem: 659405361 total, 42156404k used, 23784132k free, 77428 01 
buffers 

Swap: 999420k total,123248k used, 876172k free,2039748k cached 
PID to kill: 8 


ES  SHR S $CPU ۳ E+ COMMAND 


root 20 17864 2888 2636 S : 0:00.16 init 
syslog 20 171m 2732 2352 S : 0:00.06 rsyslogd 
root 20 19116 2032 1840 ۲ 0:00.00 cron 
root 20 50048 3468 2860 : 0:00.00 sshd 
bind 20 1128m 37m 6044 " :01.74 named 
root 20 54456 2572 2156 ۱ : 00۰.00 login 
sysadmin 20 18080 3268 2772 : : 00.01 bash 
sysadmin 20 6500 1856 1720 : : 00 ۰02 ping 
sysadmin 20 6500 1780 1644 ; :00.00 ping 
sysadmin 20 6500 1788 1652 P :00.00 ping 


sysadmin 20 17208 2300 2068 : :00.01 top 


تنفیذ الأمر PID‏ 


YAo 


37 
AN‏ اساسيات لينكس 


٥ الخطوة‎ ٥ 


في خانة الموجه والخاصة بالقضاء على العملية مع شارة :]15[ (Kill PID with signal‏ » إذا كنت تريد 
استخدام رقم الاشارة الافتراضي وهو ]15[ فقم بالضغط على مفتاح Enter‏ آما إذا كنت تريد رقم إشارة آخر 
فقم بكتابته ليتم ارساله الى العملية التي تريد إنهائها. لاحظ أن الأمر ping‏ الأول ستتم إزالته ویبقی أمر ping‏ 


واحد فقط في القائمة. 


(قد تحتاج إلى الانتظار بضع وان حتى يقوم أمر top‏ بالتحديث): 


top - 07:28:01 up 101 days, 10:55, 1 user,- load average: O0. 
y 0-70 


Tasks: 10 total, 1 running, 9 sleeping, 0 stopped, 0 zombie 


pu (s): 0.585, 1.3$sy, 0.0$ni, 98.1$id, 0.187, 0 ۰05۳3 م‎ 0 . 053 
, 0.059 تا‎ 

Mem: 65940536k total, 42373968k used, 23566568k free, 77478 16 
buffers 

Swap: 999420k total,123248k used, 876172k free, 2042156k cashed 


ES  SHR S $CPU $MI E+ | COMMAND 


root 20 17864 2888 2636 8 . 0:00.16 init 


syslog 20 171m 2732 2352 S ۲ 0:00.06 0 


root 20 19116 2032 1840 š 0:00.00 cron 
root 20 50048 3468 2860 : 0:00.00 sshd 
bind 20 1128m 37m 6044 . :01.74 named 
root 20 54456 2572 2156 ۲ : 00.00 login 
sysadmin 20 18080 3268 2772 š :00.01 bash 
sysadmin 20 6500 1780 1644 P :00.04 ping 
sysadmin 20 6500 1788 1652 š :00.04 ping 


sysadmin 20 17208 2300 2068 . 0008 


تنفیذ الضغط علی مفتاح ادخال 


YAT 


سف د 
AN‏ اساسيات لينكس 


تمعن في التالي: هناك العديد من القيم الرقمية المختلفة التي یمکن إرسالها إلى عملية. وهذه هي القیم محددة 
مسبقا ولكل منها معنى مختلف. إذا كنت ترغب في معرفة المزيد عن هذه القیم اكتب الأمر man kill‏ في 


إطار النافذة الطرفية terminal‏ 
يشير الموجه إلى ان الاشارة الافتراضية للإنهاء هي بواسطة SIGTERM‏ أو العدد .٥١‏ 
7 الخطوة ٦‏ 


انهي عملية ping‏ المتبقية كما بالسابق» ولكن في خانة الموجه والخاصة بالقضاء على العملية Kill PID with‏ 


«signal [15]‏ استخدم القيمة ۹ بدلا من العدد الافتراضي ۵ اضغط ۲ للموافقة ثم دخول. 


top - 07:29:59 up 101 days, 10:57, 1 user, load average: 1.84, 1.07 
j 0.82 
Tasks: 9 total, 1 running, 8 sleeping, 0 stopped, 0 zombie 


0.7$us, 0۰1۹559۷,  0.0$ni, 98.52$id, 0.15072, 0.091, 0.0۹3 
659405361۴ total, 424661201 used, 234744161 free, 7750241 
buffers 
Swap: 999420k total, 123248k used, 876172k free,2043532k cached 


SHR S $CPU ۳ E+ | COMMAND 


sysadmin 20 6500 1788 1652 S $ 0:00.08 ping 


root 20 17864 2888 2636 8 : 0:00.16 init 


syslog 20 171m 2732 2352 S : 0:00.06 rsyslogd 


root 20 19116 2032 1840 s 0:00.00 cron 
root 20 50048 3468 2860 : 0:00.00 sshd 
bind 20 1128m 37m 6044 : : 01.74 named 
root 20 54456 2572 2156 : :00.00 login 
sysadmin 20 18080 3268 2772 $ :00.01 bash 


sysadmin 20 17208 2300 2068 . :00.06 top 


تنفيذ التغيير إلى العدد ۹ بدلا من ٥١‏ 


YAN 


اساسیات لینکس 

تمعن في التالي : (شارة الإنهاء ۹ أو SIGKILL.‏ هي إشارة قوية " forcefull‏ " لا يمكن تجاهلهاء على 
عكس القيمة الافتراضية .٥١‏ لاحظ أنه تمت إزالة کل ما يشير إلى الأمر ping‏ من قائمة الأمر top‏ 
۱١,٤١۷‏ الخطوة V‏ 

اکتب ې للخروج من الأمر top‏ وتظهر الشاشة التالية أن كلا آمري ping‏ قد أنهيا: 


[1]- Terminated ping localhost » /dev/null 


Killed ping localhost » /dev/null 


تنفیذ الأمر |0 
٥‏ استخدام kill s pkill‏ لانهاء العمليات 


في هذه المهمة» سوف نستمر بالعمل مع العمليات. وسوف نستخدم الأمرين kills pkill‏ لانهاء terminate‏ 


processes العملیات‎ 
ETE 


للبدی اكتب الأوامر التالية في نافذة :terminal‏ 


sleep 888888 6 


sleep 888888 & 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


TAA 


اساسیات لینکس 


:~$ sleep 888888 ع‎ 


:~$ sleep 888888 ع‎ 


sleep 888888 & «sleep 888888 & تنفيذ الأمر‎ 


عادة یستخدم الأمر sleep‏ لعمل نقطة توقف pause‏ لأحد برنامج القشرة (shell script)‏ وذلك لفترة محددة 


من الزمن. في هذه الحالة یتم استخدامه مع الأمر الذي سوف يستغرق وقت طویل للتشغيل run‏ 


تأکد من ملاحظة 108 على النظام الخاص بك مع الأمر Isleep‏ سوف تكون أرقام العمليات PIDS‏ 


الخاص بك مختلفة عن التي تظهر في المعمل. 


Y الخطوة‎ ١١,٢ 


حدد determine‏ الوظائف jobs‏ التي تعمل حاليا currently running‏ بكتابة الأمر: 


jobs 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Running sleep 888888 & 


Running sleep 888888 & 


تنفیذ الأمر jobs‏ 


۸٩ 


2 
کر اساسیات لینکس 


٣ الخطية‎ 1۹٣ 


الآنء استخدم الأمر Kill.‏ لوقف التنفيذ الأول للأمر sleep‏ عن طريق كتابة PID‏ (رقم العملية للأمر sleep‏ 


الأول والذي یظهر في جهازك). ثم بعد ذلك» نفذ الأمر 055[ للتحقق من إيقاف العملية: 


05 
kill PID 


jobs 
وينبغي أن يكون التنفيذ مشابه لما يلي:‎ 


1۶ ۱۲۱ 2 
TIME CMD 


bash 
sleep 
sleep 
ps 
kill 89 
jobs 


Terminated sleep 888888 


Running sleep 888888 & 


تنفیذ الأمرین jobs «kill PID‏ 
تلميح مفید: ]13 لم تتمكن من تذكر PID‏ من العملية الأولى فقط اکتب الأمر ps‏ (عملية «(process‏ كما هو 
موضح sel‏ 
5٤‏ الخطوة > 


بعد ذلكء استخدم الأمر pkill‏ لانهاء الأمر sleep‏ المتبقي» وذلك باستخدام اسم البرنامج بدلا من PID‏ 


Ya. 


اساسیات لینکس 


pkill -15 sleep 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:-$ pkill -15 sleep 


[2]* Terminated sleep 888888 


تنفیذ الأمر pkill -15 sleep‏ 
7 استخدام 5م لتحدید وفرز العملیات 


الأمر 5م يمكن استخدامه لعرض view‏ العمليات processes‏ افتراضیا فان الأمر وم یقوم فقط بعرض 


.current shell في القشرة الحالیة‎ running processes التشغيل‎ as العملیات‎ 


ESTREINA 


ابد عملیة في الخلفية background‏ باستخدام الرمز " & " للامر ping‏ ثم قم بعرض العملیات الحالية 


current 5‏ باستخدام الأمر 5م: 


ping localhost > /16۷/ & 


ps 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


AN‏ اساسیات لينكس 


sysadminGlocalhost:-$ ping localhost > /dev/null & 


py 3 
sysadminélocalhost:-$ ps 
20 ۹ TIME CMD 
62 7 50000 0 
90 ۶ : 00 : 00 ping 


99 5 21010 21010 8 


ps «ping localhost > /dev/null 6 الأمرين‎ às 


اعمل ملاحظة بأرقام العملیات PID‏ للأمر ping‏ والتي سوف تستخدمها في خطوات لاحقة. 


۲۷ ٨۳٣ 59 


نفذ execute‏ الأمر ps‏ مع الخیار -e‏ لعرض كافة العمليات ولیس فقط العملیات التي قمت بإنشائها: 


ps -e 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


sysadminllocalhost: 
0 2/4 
1 2 E : init 
19 5 8010 rsyslogd 
29 9 8 (0/0) 2 cron 
Zu f 8100) 8 sshd 


41 7 ; ۳ named 


50 2 2 )0(0( login 


$2 2 - E bash 
98 7 : E ping 


100 7 : : ps 


اساسیات لینکس 


ونظرا لأن هذه البيئة افتراضية virtualized operating system‏ فالعمليات التي تظهر هي أقل بكثير 


من الموجودة عادة عند تشغيل نظام لينكس مباشرة directly‏ على الأجهزة .hardware‏ 
۳ الخطوة Y‏ 
استخدم الأمر 5م مع الخيار 0- لتحدید الأعمدة التي تريد إخراجها. 


ps -o ام‎ 906 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


5 ps -o 910,۲۷, 112 0206 
TIME $CPU CMD 
9100 891010۳ 0.0 OAS 


: 00:00 0.0 ping localhost 


20021010 0-0 jos. —G اتی‎ tier E UME, 9680 28 


ps -o pid,tty,time,9ecpu,cmd تنفیذ الأمر‎ 


ء ,33 الخطوة ٤‏ 


قم باستخدام الخيار --sort‏ لتحديد specify‏ أي عامود تريد فرزه. افتراضیاء سیکون الفرز تصاعديا 
ascending order‏ للعامود المحددء كما يمكن اختياره بوضع الرمز زائد " + " أمام اسم العامود. والعكس 


صحیح؛ فاستخدام الرمز ناقص " — " آمام اسم العامود كفيل بجعل عملية الفرز تنازلية. 
فرز تنفيذ الأمر وم بواسطة العامود Amem‏ 


ps -o pid,tty,time,gZ6mem,cmd --sort 7 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


اساسیات لینکس 


$ ps -o pid,tty,time,mem,cmd --sort 76 
TIME $MEM CMD 


00:00:00 0.0 ps -o pid,tty,time,$mem,cmd --sort $mem 


00:00:00 .0 ping localhost 


00: 010 0اه‎ loeum 


ps -o pid,tty,time,26mem,cmd --sort %mem تنفيذ الأمر‎ 


٥ الخطوة‎ ٥ 


في حين أن الأمر وم يمكن أن یظهر النسبة المتوية من الذاكرة التي تستخدمها عملية ماء فان الأمر free‏ يُظهر 


الاستخدام الكلي لذاكرة النظام: 


free 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


5 sexe 


total used free shared buffers 
cached 


Mem: 65969788 6242744 59727044 300852 
2284 


-/* buffers/cache: 4879608 61090180 


Swap: 2097148 0 2097148 


تنفیذ الأمر free‏ 


٦ الخطوة‎ 7 


أنهي الأمر ping‏ بو اسطة الأمر Kill‏ ثم تحقق من التنفيذ مع الأمر jobs‏ 


kill PID 


jobs 


س0 اساسیات لینکس 


وينبغي أن يكون التنفيذ مشابه لما يلي: 


kill 98‏ وہ 


:-$ jobs 


[1]* Terminated ping localhost » /dev/null 


تنفیذ الأمرين jobs «kill PID‏ 
۷ عرض سجلات النظام 


سجلات النظام System logs‏ مهمة لکثیر من المهام Us tasks‏ في ذلك تحدید مشاکل نظام التشغیل fixing‏ 
operating system‏ والتأکد ensure‏ من أن النظام الخاص بك secure od‏ معرفة مکان تخزین 
0 ملفات سجل النظام system log files‏ وكيفية المحافظة maintain.‏ عليها هو أمر مهم لمسؤول 


النظام .system administrator‏ 
هناك برنامجین خفیه daemons‏ للتعامل مع سجل الرسائل messages‏ وما: الأول syslogd‏ والثاني 
0 عادة لا تحتاج للقلق حول البرنامج klogd‏ حيث أنه يعالج bii handles‏ رسائل سجل النواة kernel‏ 


.Syslogd معلومات السجل الموجودة به الى البرنامج‎ sends ويرسل‎ log messages 


الرسائل Messages‏ التي تم إنشاؤها generated‏ من قبل النواة kernel‏ في وقت التمهيد boot time‏ 
يتم تخزينها stored‏ في الملف e ./var/log/dmesg‏ الأمر dmesg‏ بعرض viewe‏ رسائل النواة 
الحالية current kernel messages‏ » فضلا عن توفير السيطرة control‏ إذا ما تم عرض تلك الرسائل 


terminal console window في النافذة الطرفية‎ 


ملف السجل الرئيسي main log file‏ والمكتوب بواسطة البرنامج الخفي والذي يتعامل مع سجل الرسائل 


Jvar/log/messages s syslogd 


بالإضافة إلى أن التسجيل logging‏ يتم من خلال البرنامج السابق syslogd‏ فهناك العدید من العمليات 


5 الأخرى التي لديها التسجيل logging‏ الخاص بها. من الأمثلة على العمليات التي تقوم بتسجيل 


٥ 


اساسیات لینکس 


خاص بها خادم الويب آباتشي Apache web server‏ (ملف السجل log file‏ موجود في دليل 
0 مثال آخر هو نظام يونيكس للطباعة Common Unix Printing System‏ 


.(/var/log/audit) auditd daemon والبرنامج الخفي‎ (/var/log/cups) 


ملاحظة: في أنظمة «CentOS systems‏ یسمی البرنامج syslogd‏ باسم .rsyslogd‏ 


١ 2 و1‎ 


الأوامر القليلة المقبلة سوف تتطلب صلاحيات rights‏ مستخدم رئيسي ٢‏ 5006/056 استخدم الأمر راو لتبديل 


المستخدم switch user‏ إلى حساب المستخدم الجذر :root account‏ 


SU - root 


(Enter the password: netlab123) 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


Password: 


su —root تنفیذ الأمر‎ 


Y الخطوة‎ ۷۲ 


يتم تخزین stored‏ سجلات النظام system logs‏ في الدلیل /var/log‏ قم بسرد قائمة بتلك الملفات: 


90 کا 


وينبغي أن یکون التنفیذ مشابه لما يلي: 


اساسیات لینکس 


:~# ls ۳/۵ 


alternatives.log 5 cron.log faillog lastlog 
wtmp 


bootstrap.log dmesg mail.err  syslog 


auth.log btmp dpkg.log kern.log .ا‎ 


ls /var/log تنفیذ الأمر‎ 


Y الخطوة‎ ۳ 


كل ملف سجل log file‏ یمثل خدمة أو ميزة service or feature‏ على سبيل المثال؛ یعرض الملف 

09 معلومات بشأن الصلاحیات authorization.‏ أو المصادقات Uis «authentication‏ محاولات 

تسجيل دخول المستخدم user login attempts‏ البيانات الجديدة یتم تخزينها Stored‏ في الجزء السفلي 
7 من الملف. نفذ الأوامر التالیة لمشاهدة مثال على ذلك: 

ssh localhost 

(At the first prompt, type yes) 

(At the second prompt, type abc} 

(At the third prompt, type abc) 

(At the fourth prompt, type abc] 


tail -5 /var/log/auth.log 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


AS‏ اساسیات لینکس 


rootülocalhost:-i4 ssh localhost 

The authenticity of host 'localhost (::1)' can't be established. 
ECDSA key fingerprint is 

6 8328 99 3 12 و ور 983 9151815 21815797/7 9:895 3226 د5 2018 24 822 5178 

Are you sure you want to continue connecting (yes/no)? yes 
Warning: Permanently added 'localhost' (ECDSA) to the list of known 
MOS E 5 و‎ 

rootülocalhost's password: 

Permission denied, please try again. 

rootülocalhost's password: 

Permission denied, please try again. 

rootülocalhost's password: 

Permission denied (publickey,password). 


rootülocalhost:-^4 tail -5 /var/log/auth.log 


Apr 8 20:25:13 localhost sshd[117]: pam unix(sshd:auth): 
authentication failure; logname- uid-0 euid-0 tty-ssh ruser- 
rhost-localhost user-root 


Apr 8 20:25:16 localhost sshd[117]: Failed password for root from 
port 58940 ssh2 


Apr 8 20:25:28 sshd[117]: last message repeated 2 times 
Apr 8 20:25:28 localhost sshd[117]: Connection closed by ::1[preauth] 


Apr 8 20:25:28 localhost sshd[117]: PAM 2 more authentication 
failures; logname- uid-0 euid-0 tty-ssh ruser- rhost-localhost 
USE 6 ٣ 


rootGlocalhost: ~# 


تنفيذ ملف السجل 


تم استخدام الأمر ssh‏ لتولید البيانات في الملف /var/log/auth.log‏ يتم تسجيل حتى محاولات الدخول 


الفاشلة في الملف .var/log/auth.log/‏ 


٤ الخطوة‎ ٤ 


لروية مثال آخر على ادخالات السجل dog entries‏ نفذ الأوامر التالية: 


۳۹۸ 


وينبغي أن يكون التنفيذ كالتالي: 


اساسيات لينكس 


crontab -e 


Edit this file to introduce tasks to be run by cron. 


Each task to run has to be defined through a single line 


indicating with different fields when the task will be run 


to run for the task 


and what command 


To define the time you can provide concrete values for 


(mon), 


(for 'any').4 


(hn), day of month (dom), month 


(dow) or use '*' in these fields 


minute (m), hour 


and day of week 


Notice that tasks willbe started based on the cron's system 


sent through 


(unless redirected). 


daemon's notion of time and timezones. 


Output of the crontab jobs (including errors) is 


email to the user the crontab file belongs to 


For example, you can run a backup of all your user accounts 


at 5 a.m every week with: 


0 5 * * 1 tar zcf /var/backups/home.tgz /home/ 


For more information see the manual pages of crontab(5) and cron(8) 


command 


crontab -e تنفیذ الأمر‎ 


۳۹۹ 


mh dom mon dow 


IL 
Iu 


> پس 


3 اساسیات لینکس 2030 
مع ESC‏ ثم wg‏ وأخيرا مفتاح أدخال :Enter‏ 


02**0 who << ۵ 
> ESC > 
wq 


Enter >‏ < 
بعد الانتھاء من التعدیلاتء اعرض ملف السجل لخدمة crontab‏ عن طريق الأمرين التاليين: 


crontab -l | tail -2 


tail /var/log/cron.log 


قم بإضافة السطر التالي إلى الوثیقة (تذکر حرف أ سوف يسمح لك بالدخول إلى وضع إدراج) ثم حفظ والخروج 
وينبغي أن يكون التنفيذ مشابه لما يلي: 
| 


mi 


INFO 556 


STARTUP (fork ok) 


INFO (Running 


cd / && 


BEGIN EDIT (root) 


REPLACE (root) 
END EDIT (root) 


IS (156915) 


٥ الخطوة‎ ٥ 


اساسیات لینکس 


| tail -2 


command 


<< /tmp/whothere 


tail /var/log/cron.log 


/usr/sbin/cron[22]: 


/usr/sbin/cron[23]: 


/usr/sbin/cron[23]: 


/USR/SBIN/CRON[79]: 


/USR/SBIN/CRON[82]: 


/USR/SBIN/CRON[99]: 


886 | 121 l| 5 
8 121. l| £ 
2786006 1.21. || : 


CE EOE A ٤ 


تنفيذ مثال على مدخلات السجل 


rootülocalhost:-4 crontab -l 


4mh dom mon dow 
0 2 8 7 0 who 
root6localhost: : ٭۔‎ 


Apr 8 17:33:32 localhost 


fd 
Apr 8 17:33:32 localhost 


Apr 8 17:33:32 localhost 
Qreboot jobs) 


Apr 8 18:17:01 localhost 
12101۱۱۵16 اع‎ = 


-report /etc/cron.hourly) 


Apr 8 19:17:02 localhost 
12۱01۱۱۵1 ES = 


-report /etc/cron.hourly) 


Apr 8 20:17:01 localhost 
بلاط‎ 221 25 = 


-report /etc/cron.hourly) 


:18 localhost 
:42 localhost 
:42 localhost 
:19 localhost 


rootGlocalhost: ~# 


اعرض الأسطر الخمسة الأخيرة من الملف /var/log/dmesg‏ لروية رسائل النواة kernel messages‏ 


من وقت التمهيد «boot time‏ ثم نفذ الأمر dmesg‏ مع الأمر tail‏ لعرض رسائل النواة الخمسة الماضية: 


tail -< 0 


dmesg | tail -5 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


rootelocalhost:-4 tail -5 /var/log/dmesg 


[ 2.922003] type-1400 audit(1386098331.347:10): apparmor-"STATUS" 
operation-"profile load" name-"/usr/sbin/tcpdump" pid-848 
comm-"apparmor parser" 


.989112] Bridge firewalling registered 


.007035] ip tables: (C) 2000-2006 Netfilter Core Team 


20/0733] ME ۵1۳۲9۹ 22297 0-5-0 (16384 bucekets,; 6559/6 max) 


.020096] input: ImPS/2 Generic Wheel Mouse a 
/devices/platform/i8042/seriol/input/input2 


rootélocalhost:-4 dmesg | tail -5 
[279447.718341] device veth0pli7180 left promiscuous mode 


[279447.718408] br998ad950-5830: port 1(veth0pli7180) entered 
disabled state 


[279448.519497] bre2e72298-4b5e: port l(veth0pli7664) entered 
disabled state 


[279448.525087] device vethO0pli7664 left promiscuous mode 


[279448.525091] bre2e72298-4b5e: port 1l(veth0pli7664) entered 
disabled state 


rootelocalhost:-4 


dmesg | tail -5 «tail -5 /var/log/dmesg الأمرين‎ 33x 


من المحتمل ان تتساءل الآن ماذا تعني کل هذه الرسائل؟ الجواب على هذا السؤال لیس بسیط ولكن هذا الدرس 
لا يهدف إلى شرح explain.‏ معنى جميع رسائل السجل «Log messages‏ وانما لمعرفة أين توجد where‏ 


to find‏ تلك الرسائل. 


وكلما اكتسبت المزيد من الخبرة في التعامل مع نظام التشغيل لينكس «Linux‏ فسوف las‏ في استكشاف المشاكل 
وحلها troubleshoot problems‏ وفي معظم المشاكل التي قد تواجههاء فان المكان الأول الذي تريد أن 


تتحقق منه هو ملفات السجل og files‏ 


من أجل توفير مثال واقعي لاستكشاف الأخطاء وإصلاحهاء قم بتنفيذ المجموعة التالية من المهام. 


اساسیات لینکس 


٦ الخطوة‎ V, 


us‏ أنك في حساب المستخدم الجذر root user‏ أدخل الأمر التالي لتعطيل disable‏ قدرة ability‏ المستخدم 
sysadmin user‏ من انشاء (دخالات في ٥٥180‏ 6؛ ثم قم بالخروج من حساب المستخدم الجذر والانتقال 


إلى حساب المستخدم :sysadmin‏ 


echo "sysadmin" > /etc/cron.deny 


exit 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


echo "sysadmin" > /etc/cron.deny‏ رتو 


:~# exit 


exit «echo "sysadmin" » /etc/cron.deny تنفیذ الأمرین‎ 


۷۷ الخطوة ۷ 


حاول تنفيذ الأمر crontab‏ التالي: 


crontab -e 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


5 crontab -e 


You (sysadmin) are not allowed to use this program (crontab) 


See crontab(1) for more information 


وب : 


محاولة تنفیذ الأمر crontab -e‏ 


۳۰۳ 


اساسیات لینکس 


ملاحظة: یفشل هذا الأمر بسبب وجود اسم المستخدم في الملف 1 . في حالة وجود اسم المستخدم 


في الملف السابق؛ فانه لا يمكنه استخدام الأمر .crontab‏ 


۸ الخطوة ^ 


Ya‏ من تبديل المستخدم switching user‏ إلى مستخدم جذر root‏ مع الأمر sgU‏ استخدم الأمر sudo‏ لتنفیذ 


الأوامر بامتیازات الجذر root privileges‏ كما في المثال التالي: 


sudo tail -< ۳۵۰09 


(Enter the password: netlab123) 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


2۰2۱۹۸6۷3 روه‎ ٤ب‎ 
password for 7 
20:31:18 localhost crontab[121]: (root) BEGIN EDIT (root) 
20:32:42 localhost crontab[121]: (root) REPLACE (root) 
20:32:42 1-1 51 طمن قت م‎ ]121[ ۶: (eo) IND EDIT (exc) 


20:33:19 localhost crontab[132]: (root) LIST (root) 


Apr 20:47:06 localhost crontab[139]: (sysadmin) AUTH (crontab 
command not allowed) 


sudo tail -5 /var/log/cron.log تنفيذ الأمر‎ 


US,‏ هو ملاحظ في السطر الأخير من تنفیذ الأمر tail‏ فإنه لا يُسمح للمستخدم sysadmin‏ من استخدام الأمر 


.crontab 


AW‏ اساسیات لینکس 
|۸ المکتبات المشتركة 


المكتبات المشتركة Shared libraries‏ هي ملفات تحتوي على اكواد (تعليمات برمجیة)» حيث يمكن لملفات 
البرنامج program files‏ القابل للتنفيذ executable program‏ الارتباط link‏ بتلك المکتبات من أجل 
استخدام الاکواد الموجودة بها بدلاً من كتابتها مرة آخری. وبسبب أن العديد من البرامج multiple programs‏ 
Ule‏ ما ترتبط بملف مكتبة واحد tsingle library‏ فان ذلك يساعد على تقليل reduce‏ مقدار المساحة 
space‏ المطلوبة لتنفيذ هذا الکود. وبعبارة أخرى البرنامج يستطيع استدعاء أحد المكتبات متی ما أراد ذلك 


وبالتالي لا یحتاج الى وجود نسخة خاصة al SG‏ تلك المكتبة Alla,‏ 

وغالبا ما تخزن stored‏ ملفات المكتبات library files‏ في الدليلين /lib‏ و /usr/lib‏ ويمكن إدراج دلائل 
إضافية additional directories‏ عن طريق تحرير ملف التكوين «configuration file‏ 
etc/Id.so.conf/‏ أو يمكنك أيضا إنشاء create‏ ملفات files‏ تنتهي بالامتداد التالي conf.‏ ووضعها في 


الدليل /۵]0/۱0.50.60۳0۲.0. وأخيراء يمكنك Laj‏ تعيين Set‏ متغير البيئة environment variable‏ 


LD_LIBRARY_PATH quii‏ كذلك. 
آ ر١1‏ الخطرة ١‏ 


عند التنفیذ execute‏ بحساب المست تخدم الجذر ‘root‏ فان الأمر ldconfig‏ يمكن استخدامه لتحديث update‏ 
ذاكرة التخزین cache‏ والروابط الرمزية symbolic links‏ للمکتبات المشتركة shared libraries‏ في 
النظام. كمستخدم عادي an ordinary user‏ سوف تقوم بتنفيذ الأمر ldconfig‏ لطباعة print‏ قائمة المكتبات 


المشتركة list of shared libraries‏ كالتالي: 


ldconfig -p | less 


وينبغي أن يكون التنفیذ الجزئي كالتالي: 


۳ 
^W‏ اساسیات لينكس 


148 libs found in cache "^/etc/ld.so.cache' 


libz.so.1 (libc6,x86-64) => /lib/x86 64-linux- 
gnu/libz.so.1 

libxml2.s0.2 (libc6,x86-64) => /usr/lib/x86 64-linux- 
gnu/libxml2.s0.2 

libxcb.so.1 (libc6,x86-64) => /usr/lib/x86 64-linux- 
gnu/libxcb.so.1 

libwrap.so.0 (libc6,x86-64) -» /lib/x86 64-linux- 
gnu/libwrap.so.0 

libwind.so.0 (libc6,x86-64) -» /usr/lib/x86 64-linux- 
gnu/libwind.so.0 

libuuid.so.1 (libc6,x86-64) -» /lib/x86 64-linux- 
gnu/libuuid.so.1 

libutil.so.1 (libc6,x86- 
64, OS ABI: Linux 2.6.24) => /lib/x86 64-linux-g 
nu/libutil.so.1 


libusb-1.0.so.0 (libc6,x86-64) => /lib/x86 64-linux-gnu/libusb- 
1.0.9050 5 

libusb-1.0.so.0 (libc6,x86-64) => /usr/lib/x86 64-linux- 
gnu/libusb-1.0.s 
Qui 


libusb-0.1.so.4 (libc6,x86-64) -» /lib/x86 64-linux-gnu/libusb- 
0 4ھ‎ 5 

libunistring.so.0 (libc6,x86-64) -» /usr/lib/x86 64-linux- 
gnu/libunistri 
119 0 


libudev.so.0 (libc6,x86-64) -» /lib/x86 64-linux- 
gnu/libudev.so.0 

libtinfo.so.5 (libc6,x86-64) -» /lib/x86 64-linux- 
gnu/libtinfo.so.5 

libtic.so.5 (libc6,x86-64) -» /usr/lib/x86 64-linux- 
gnu/libtic.so.5 

libthread db.so.1 (libc6,x86- 
64, OS ABI: Linux 2.6.24) => /lib/x86 64-l 
nux- 
gnu/libthread db.so.1 


libtasnli.so.3 (libc6,x86-64) => /usr/lib/x86 64-linux- 
gnu/libtasni.so.3 

libstdc4*4.so.6 (libc6,x86-64) => /usr/lib/x86 64-linux- 
gnu/libstdc++.so. 
6 


ldconfig -p | less تنفيذ جزني للأمر‎ 


اساسیات لینکس 


تذكر الضغط على الحرف q‏ لأنهاء صفحات الامر اقل less pager‏ 


٨٣ 23‏ ؟ 


من أجل عرض view‏ المکتبات libraries‏ والمرتبطة بملفات القابلة للتنفیذ linked to an executable‏ 


مثل /bin/bash‏ نفذ الأمر 00): 


ldd /bin/bash 


وينبغي أن یکون التنفيذ مشابه لما يلي: 


:~$ ldd /bin/bash 
linux-vdso.so.1 <<  (0x00007ffce6fbd000) 


libtinfo.so.5 -» /lib/x86 64-linux-gnu/libtinfo.so.5 (0x00007fb 
32ae94000) 


libdl.so.2 => /lib/x86 64-linux-gnu/libdl.so.2 (0x00007f£532ac900 


libc.so.6 => /lib/x86 64-linux-gnu/libc.so.6 (0x00007f£532a8d100 


/lb64/ld-linux-x86-64.s0.2 (0x0000563ddfa4e000) 
وہ‎ 


ldd /bin/bash الأمر‎ x 


و 
کے ہے کی 
AN‏ اساسيات لينكس 230 
iA Pun‏ 


المعمل الثاني عشر - تكوين الشبكة 


Network Configuration 


۸ 


E 
n ———————X ————U['—'ÁÁ————————"H—————"————— E 


IL 


2/530 اساسیات لینکس‎ EA 


١‏ مقدمة 


هذا هو المعمل الثاني عشر: تكوين الشبكة. عن طريق أداء هذا التمرین» سوف تتعلم حول تكوين جهاز الحاسب 
الخاص بك على الشبكة. 


٢‏ استکشاف الشبكة 


في هذه المهمة» سوف تقوم بتنفيذ بعض الأوامر ودراسة بعض الملفات بهدف عرض تكوين configuration‏ 


شبكة الاتصال. 
0١‏ الخطوة ۱ 
من أجل تحديد عنوان بروتوكول الإنترنت الخاص بجهازك (IP)‏ نفذ الأمر التالي: 
ifconfig‏ 


وينبغي أن يكون التنفیذ مشابه لما يلي: 


تہ سسسسسنس:( اص کا 
4 
z‏ 
-D‏ 


7۳۳ اساسیات لینکس 


sysadmin@localhost:~$ ifconfig 

ETAO Link 

encap:Ethernet HWaddr 3a:3b:65:10:f6:43 
inec 21 رم ام 68 1 7 192 و‎ 1892250 0-0-0 Masks 7-0 
هه اه‎ 1,290 2222177 95:: 21210216 2/624 529225 LIRE 
UP BROADCAST RUNNING MULTICAST ۳1۳0:1500 Metric:1 
RX packets:15 errors:0 dropped:0 overruns:0 frame:0 
TX packets:9 errors:O0 dropped:0 overruns:0O0 carrier:0 
collisions:0 txqueuelen:1000 


RX bytes:1206 (1.2 KB) TX bytes:690 (690.0 B) 


Link encap:Local Loopback 

mert 212127 0-0.1 09869 7 ۵ 

2258 2211۶58 351/126 80 HOSE 

UP LOOPBACK RUNNING ۳0: 69936 Merrie: i 

RX 02016619: 0 ہ۶ دہ‎ :0 dropped:0 overruns:O0 0 
TX packets:0 errors:0 dropped:0 overruns:0O0 carrier:0 
collisions:0 txqueuelen:0 


RX 9722510 (0.0 B) 1X 97223710 (0.0 1) 


sysadmin&localhost: ~$ 


تنفیذ الأمر ifconfig‏ 


يظهر في التنفيذ مجموعتين two blocks‏ من المعلومات sinformation‏ المجموعة الأولى تبداً من ETHO‏ 
وتعطي معلومات عن أول بطاقة شبكة من نوع إیثرنت LÍ „Ethernet network card‏ المجموعة الثانية 
فتبدأ من ما وتعکس معلومات حول الاسترجاع loopback‏ أو واجهة الشبكة الداخلية internal network‏ 


interface 


السطر التاني في کل مجموعة یحتوي علی معلومات ذات صلة pertinent‏ بالاصدار الرابع 4 Version‏ من 
بروتوكول الانترنت (وتسمی عناوين ۱۳۷4) في حين أن السطر الثالث لديه معلومات عن الإصدار السادس من 


بروتوكول الانترنت (الإصدار ۱۳۷6). ان عناوين ۱۳۷4 هي وسيلة قديمة لتحديد الأجهزة identifying‏ 


Yje 


و اساسیات لینکس 2230 


machines‏ عن طريق سلسلة من الأرقام «series of numbers‏ وهو لا یزال یستخدم على نطاق واسع 


الیوم على الرغم من أن الاصدار السادس المحسن ۱۳۷6 improved‏ متاح منذ سنوات. 


یتم عرض عناوين ۱۳۷4 على شكل أربعة أرقام عشرية four decimal numbers‏ تتراوح من ۰ إلى ۲۵۵ 
äl paia‏ بنقاط „periods‏ 

اما عناوین ۱۳۷6 فهي مكونة من Y YA‏ رقم يتم عرضها كخانات ست عشرية hexadecimal digits‏ تتراوح 
من ۰ إلى ]. الأرقام الست عشرية عموما مقسمة إلى مجموعات من أربعة أرقام groups of four digits‏ 
مفصولة بنقاط colons‏ إذا کان العدد مكون من أرقام منتالية consecutive‏ ست عشرية بقيمة صفر؛ فسيتم 


استبدالها بائنین من النقاط „two colons‏ 


Yo EN‏ اط 


وجود عنوان IP‏ یسمح للنظام الخاص بك your system‏ من التواصل communicate‏ مع الانظمة 
الأخرى other systems‏ على نفس الشبكة same network‏ اما للتواصل مع آنظمة آخری على شبكات 
مختلفة other networks‏ فيم ذلك عن طريق أجهزة التوجيه routing devices‏ لعرض جدول معلومات 
التوجیه stable of routing information‏ استخدم الأمر :route‏ 


route 


route -n 


وينبغي أن يكون التنفيذ مشابه لما پلي: 


اساسیات لینکس 


:-$ route 
Kernel IP routing table 


Destination Gateway Genmask Metric Ref 
se Iface 


08ھ 225 255 0( 5 1 4 168 . 92 1 
0 0 


5 route -n 


Kernel IP routing table 


Destination Gateway Genmask Flags Metric Ref 
se Iface 


0ء 258 2553 ۷ 50 50 9 1.0 1168 . 1192 
0 0 


route -n «route تنفیذ الأمرين‎ 


لاحظ أن تنفيذ الأمر route‏ الأول هو أرقام مع وجود ب بعض الرموز مثل الرمز " * ". آما في التنفیذ الثاني للأمر 


route مع الأمر‎ -n فنجد أرقام بدلا من الرموز السابقة وذلك نتيجة لاستخدام الخیار‎ route 


عند الاتصال connecting to‏ بأجهزة الحاسب الأخرى فيتم استخدام إما عنوان [P‏ أو اسم المضيف 
© ريمكن استخدام أسماء المضيفين Hostnames‏ إذا تم إدخالها في ملف /etc/hosts‏ جنبا إلى 
جنب مع عناوين IP‏ المرتبطة بهاء أو إذا كان خادم اسم المجال Domain Name Server -(DNS)‏ يعطي 


عنوان IP.‏ إلى برنامج ترجمة أسماء المضيفين .host name translation‏ 


زوجان من الأسماء couple of names‏ التي تكون عادة موجودة في الملف localhost  /etc/hosts‏ 


.current machine إلى الجهاز الحالي‎ refer يستخدم للإشارة‎ Ua 9S cL ocalhost.localdomain و‎ 


Y الخطوة‎ Y, Y 


تحقق من أن عنوان IP‏ التالي 127.0.0.1 له ادخال entry‏ في الملف /etc/hosts‏ 


grep 127.0.0.1 /etc/hosts 


Yyy 


A‏ اساسیات لینکس 


يجب أن يظهر التنفيذ على النحو التالي» تحديد أسماء :localhost‏ 


:-$ grep 127.0.0.1 /etc/hosts 


localhost 


وه : 


grep 127.0.0.1 /etc/hosts تنفیذ الأمر‎ 


یمکن استخدام الأمر ping command‏ لمعرفة ما اذا کان النظام متصلا connected.‏ في الوقت الراهن 


۷ بالشبكة أو لا. 


في بعض «oos YI‏ یتم تکوین configured‏ النظام لعدم الاستجابة لطلبات الأمر ping.‏ ولذلك فان عدم وجود 


استجابة lack of a response‏ للامر ping‏ لا يعني ان النظام غير متصل بالشبكة. 


id ٤ 


حاول معرفة ما إذا کان الجهاز localhost‏ سیستجیب لطلبات requests‏ اختبار الاتصال ping‏ الأربعة عن 


طریق الأمر التالي: 


ping -c4 localhost 


ويكون التنفيذ مشابهه لما يلي: 


YY 


اساسیات لینکس 


$ ping -c4 localhost 
PING localhost (127.0.0.1) 56(84) bytes of data. 
64 bytes from localhost (127.0.0.1): icmp req-1 
64 bytes from localhost (127.0.0.1): icmp req-2 


64 bytes from localhost (127.0.0.1): icmp req-3 


64 bytes from localhost (127.0.0.1): icmp req-4 


--- localhost ping statistics --- 
4 packets transmitted, 4 received, 0$ packet loss, time 2998ms 


rtt min/avg/max/mdev = 0.028/0.036/0.045/0.007 ms 
$ 


ping -c4 localhost تنفیذ الأمر‎ 


على عكس الأمر ping‏ المتوفر في نظام التشغيل مایکروسوفت ویندوز Microsoft Windows‏ 
«operating system‏ فان الحالة الافتراضية للأمر ping.‏ في لينكس Linux.‏ هي عدم التوقف عن إرسال 
طلبات الاختبار. فإذا كنت قد نسیت تحدید الخيارم-؛ فیجب عليك وقف الأمر یدویا manually‏ عن طريق 


الضغط على مفتاح التحکم والمفتاح © (CTRL + c)‏ 


ویمکن أيضاً الاستفادة من أسماء المضیفین Hostnames‏ إذا كانت مسجلة registered‏ في خادم اسم المجال 
(DNS)‏ فإذا کان النظام الخاص بك connected Sai‏ مع خوادم (DNS‏ فعندها سیقوم مُدخل أسم الخادم 
۲ في الملف etc/resolv.conf/‏ بتکوین configures‏ النظام الخاص بك لاستخدام هذه 


الخوادم لحل resolve‏ آسماء المضیفین hostnames‏ إلى عناوین JP.‏ 


o الخطوة‎ 1 Y, Y,o 


اعرض الملف etc/resolv.conf/‏ لمعرفة هل توجد إدخالات entries exists‏ لاسم الخادم 


۲۴ 6ء 


cat /etc/resolv.conf 


AW‏ اساسیات لینکس 


يجب أن يظهر في التنفیذ ادخال entry‏ لاسم خادم nameserver‏ واحد: 


:-$ cat /etc/resolv.conf 


nameserver ۳۶۶۷ 


:~$ 


تنفیذ الام ر cat /etc/resolv.conf‏ 


٦ الخطوة‎ ں٦‎ 


استخدم الأمر dig‏ والخاص بالبحث لاعادة تحويل resolve‏ الاسم localhost.localdomain‏ إلى عنوان 


JP 
dig localhost.localdomain 


ويكون التنفيذ مشابهه لما پلي: 


Yo 


E‏ اساسیات لینکس 


sysadminGlocalhost:^$ dig localhost.localdomain 


; ««»» DiG 9.8.1-P1 ««»» localhost.localdomain 

;; global options: 8 

CR Cor user 

aig $9943‏ ۷۷ 217 ئا :310181 هون کر Bp‏ 


;; flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 1, ADDITIONAL: 


Eg QUESTION 1 SECTIONS 


;localhost.localdomain. 


;; ANSWER SECTION: 


localhost.localdomain. 86400 IN 127 200 و 0اه‎ 


7 ٔ, 110 0 :20/11118 رم 


IN localhost .localdomain.‏ 86400 . 0 1 ۶ ها 


Query time: 803 msec 
SERVERS 1127-0-0- 15:99 (1,27 a9 5 (0) 4 11) 
WHEN: Mon Apr 11 13:33:03 2016 


MSG SIZE revels 69 


sysadminllocalhost:~$ 


dig localhost.localdomain تنفيذ الأمر‎ 


لاحظ في التنفیذ السابق أن أسماء الخوادم nameserver‏ الأولى التي تم عرضھا listed‏ في الملف 
7 هي التي استجابت responded‏ كما هو واضح في قسم الاجوبة ANSWER‏ 


SECTION‏ في الشكل السابق. 


Yn 


7 اساسیات لینکس 


۷ الخطوة‎ ٧۷ 


يمكنك استخدام الأمر dig‏ والخاص بالبحث لإعادة تحويل resolve‏ أسماء المجالات اللائقة الكاملة fully‏ 
qualified domain names‏ الأخرى. (is‏ الأمر dig‏ لاعادة تحويل اسم المضيف 


IP إلى عنوان‎ cserver.example.com 


dig cserver.example.com 
ويكون التنفيذ مشابهه لما يلي:‎ 


sysadminGlocalhost:-«$ dig cserver.example.com 
م‎ sx DG فاحل وان‎ sx cserver.example.com 
global options: 767 
Got answer: 
-»2»2HEADER««- opcode: QUERY, status: NOERROR, id: 57203 


flags: qr aa rd ra; QUERY: 1, ANSWER: 1, AUTHORITY: 1, ADDITIONAL: 


و QIUISSIJEONI SEC‏ رم 

;cserver.example.com. 

;; ANSWER SECTION: 

cserver.example.com. 1192 19 s 1 52 


CR AULHORT NE 7742 


example.com. example.com. 


20 

example.com. 86400 192.168.1.2 
;; Query time: 990 msec 

pg Sumwumms 127].02:0.13595(127 409 ۸۳۰ 

;; WHEN: Mon Apr 11 13:45:38 2016 

gp SG SIAD rowch 3 


sysadmin&localhost: ^$ 


dig cserver.example.com تنفیذ الأمر‎ 


Yyy 


IL 
Tm 


2030 اساسیات لینکس‎ RS 


الذي يكون المضيف hostname‏ فیه. اسم المجال اللائق *cserver.example.com U (FQDN)‏ 


فان cserver‏ هو اسم المضیف hostname‏ و example.com‏ هو المجال. 


۸27 


آمر dig‏ خاص بالبحث لاعادة تحويل الاسم إلى عنوان «IP.‏ ولكن الخيار ×- يعكس العملية وتحويل عنوان IP‏ 


إلى اسم للعنوان 192.168.1.2 كما يظهر في التنفیذ التالي: 
dig -x 192.168.1.2‏ 


ويكون التنفيذ مشابهه لما يلي: 


اسم المجال اللائق بالكامل (FQDN)‏ لا يشمل فقط اسم المضيف hostname‏ وإنما أيضاً المجال domain‏ 
۳1۸ | 


0 


اساسیات لینکس 


sysadminGlocalhost:-$ dig -x 242 
تک‎ Due مول و9‎ <<>>  ‌‌‌‌‌‌‌ً 2ل 1ن‎ 
global options: 84 


Got answer: 


-»2»2HEADER««- opcode: QUERY, status: NOERROR, id: 26791 


2, AUTHORITY: 1, ADDITIONAL: 


65679۷761 ٠ example .com. 


example.com. 


example.com. 


192.168.152 


flags: qr aa rd ra; QUERY: 1, ANSWER: 


OUESTION SECTION: 

s ٥‏ 20 081 19 168 ط و 

ANSWER SECTION: 
2۰1۳۷66۰1۷99۰0۳ 2609 1 8 0 
21۳66۰1٣92۰710 2019 4 0 
Bg ۶ ھ۹7٤‎ 
11-1188-18230886 EOE. 78 
;; ADDITIONAL SECTION: 
example.com. 86400 IN 

Query time: 0 msec 

SERVERE 127.050.1553 (127.490.5051) 

MS Mom Moe ۰ ہہ‎ AOL 


MSG SIZE revels 119 


sysadminllocalhost:~$ 


dig -x 192.168.1.2 تنفيذ الأمر‎ 


4 ss 9ه‎ 


ينفذ الأمر netstat‏ مجموعة كبيرة ومتنوعة من المهام المتعلقة بالشبکات. للحصول على فكرة عن بعض من 


قدراته» نفذ الأمر مع خیار :"--help"‏ 


وفيما يلي تنفيذ جزئي للامر السابق: 


netstat --help 


۳۹ 


^S‏ اساسيات لینکس 


sysadminGlocalhost:-«$ netstat --help 


usage:netstat [-vWeenNcCF] [«Af»] -r 
netstat (-V|--version|-h|--help 
netstat [-vWnNcaeol] [«Socket» 
netstat ( [-vWeenNac] -i | [-cWnNe] 
--route display routing table 


--interfaces display interface table 


--groups display multicast group memberships 


=- TAC LST LES display networking statistics (lik SNMP 
--masquerade display masqueraded connections 
SS VERIO SE be verbose 
--wide donit 1672008968 LE هه‎ 8 
--numeric don't resolve 
--numeric-hosts don't resolve host names 
--numeric-ports don't resolve port names 
--numeric-users don't resolve user names 
-N. --symbolic resolve hardware names 
-e. --extend display other/more information 


Bé ۰  -.. ة8‎ display PID/Program name for sockets 


تنفيذ جزني للامر netstat --help‏ 


listening التي تقوم بالاستماع‎ services هو تحديد الخدمات‎ netstat الاستخدامات الشائعة للامر‎ asd 
Secure على سبيل المثالء يتم استدعاء خدمة‎ incoming connection e$ إلى اتصال أو انتظار اتصال‎ 
عن بعد‎ logins بإجراء عملیات تسجيل الدخول‎ users والتي تسمح للمستخدمين‎ SHell or SSH 

6 أو من شبكة network‏ . عادة تقوم خدمة SSH‏ بالاستماع listen‏ إلى المنفذ رقم 22 في طبقة 


.TCP 


۳۲۰ 


اساسیات لینکس 


الجدول التالي يظهر استخدامات الامر netstat‏ مع عدد من الخيارات والتي ظهرت في التنفيذ السابق للأمر 


:netstat --help 


الأمر 

netstat -t 
netstat -u 
netstat -w 
netstat -x 
netstat -a 
netstat -l 
netstat -n 


netstat --numeric-hosts 


netstat --n umeric-po rts 


netstat --numeric-users 


netstat -N 


netstat -e 


netstat 0 


netstat -p 


netstat -v 


المعنی 

لعرض قنوات الاتصال sockets‏ لطبقة tcp‏ 

لعرض قنوات الاتصال sockets‏ لطبقة .udp‏ 

لعرض قنوات الاتصال sockets‏ لطبقة „raw‏ 

لعرض قنوات الاتصال sockets‏ لطبقة „unix‏ 

لعرض جمیع قنوات الاتصال sockets‏ سواءا في Als‏ استماع أو لا. 
للاستماع الى احد المنافد. 

لعرض النتانج علی شکل ارقام. 

عرض عناوین المضیف على شکل ارقام دون التأثیر على اسم المنفذ أو 
المستخدم. 

عرض المنافذ على شکل ارقام دون التأثیر على اسم المضیف أو آسماء 
المستخدمین. 

عرض معرفات المستخدم على شكل ارقام» دون التأثير على اسم المضیف 
از اسنا اف 

عرض آسماء العتاد. 

عرض معلومات إضافية. 

عرض المعلومات information‏ والمتعلقة بالمؤقت الشبكي 
.hetworking timers‏ 

عرض process id -(PID)‏ وأيضا اسم البرنامج الذي ينتمي إليه كل 
مأخذ توصيل .Socket‏ 


اعرض الحدث. 


netstat —c 


netstat —r 


netstat — i 


netstat -g 


netstat -M 


netstat -5 


netstat -W 


netstat -F 


netstat -C 


netstat -V 


اساسیات لینکس 


طباعة المعلومات المحددة کل ثانية بشكل متواصل. 

لعرض معلومات جدول التوجيه. 

لعرض الواجهات (interfaces)‏ 

عرض معلومات عضوية مجموعة البث المتعدد multicast‏ ل ۱۳۷4 
و IPv6‏ 

عرض قائمة بالاتصالات .masqueraded‏ (برنامج اتصال خاص 
بلینکس مشابه لنظام (1:many‏ 

عرض تلخیص باحصائیات كل بروتوکول. 

عدم اقتطاع عناوین [P‏ باستخدام تقنية إخراج واسع حسب الحاجة. 
(output as wide as needed)‏ 

طباعة جدول معلومات التوجیه وذلك من (Forwarding‏ 
Information Base : FIB)‏ 

طباعة معلومات التوجیه من SIS‏ $ الطرق الموجودة في ذاكرة cache‏ 
Ya‏ من FIB‏ 


الاصدار 


جدول یوضح خيارات الأمر netstat‏ 


المنافذ المعروفة Well-known ports‏ هي الموجودة في نطاق ۰1023-0 وتستخدم عادة من قبل عملیات 


النظام system processes‏ وذلك بغرض لتوفیر provide‏ خدمات الشبكة .hetwork services‏ 


ویمکن الاطلاع على قائمة الخدمات service names‏ و أسماء وأرقام المنافذ المرتبطة associated port‏ 


Jetc/services في الملف‎ numbers 


استخدم الامر التالي لعرض قائمة بأسماء وارقام المنافد :ports‏ 


cat 5 


۳۳۲ 


اساسیات لینکس 


التنفيذ التالي هو تنفيذ جزئي لأسماء وأرقام المنافذ 0/15 م: 


sysadminGlocalhost:-$ cat 56 


# Network services, Internet style 
# 


# Note that it is presently the policy of IANA to assign a single 
well-known 

# port number for both TCP and UDP; hence, officially ports have two 
entries 

$ even if the protocol doesn't support UDP operations. 


# 


# Updated from http://www.iana.org/assignments/port- 
numbers and other 
# sources like http://www.freebsd.org/cgi/cvsweb.cgi/src/etc/services 


# New ports will be added on request if they have been officially 
assigned 
$ by IANA and used in the real- 
world or are needed by a debian package. 
# If you need a huge list of used numbers please install the nmap 
package. 
tcpmux 1/tcp # TCP port service multiplexer 
echo 7/tcp 
echo 7/udp 
discard 9/tcp sink null 
discard 9/udp sink null 
systat 11/100 users 
13/tcp 
13/udp 
م15۸6‎ 
17/tcp quote 
18/tcp # message send protocol 
18/udp 
19/tcp ttytst source 
19/udp ttytst source 
20/tcp 
21/tcp 
21/136 06 
227 # SSH Remote Login Protocol 
22/udp 
23/tcp 
25/tcp mail 
5 tep timserver 
37/udp timserver 


cat /etc/services 4» تنفیذ جزئي‎ 


YY 


اساسیات لینکس 


AT CARLA 


استخدم الأمر netstat‏ لمعرفة ما إذا کان منفذ TCP‏ لخدمة ssh‏ (منفذ 22( 444 عملية استماع: 


netstat —tl 


netstat -tln 


ويكون التنفيذ مشابهه لما يلي: 


5 netstat -tl 


Active Internet connections (only servers) 


Proto Recv-Q Send-Q Local Address Foreign Address State 


tcp 0 0 example.com:domain 24 LISTEN 
tcp 0 0 localhost:domain *i* LISTEN 
[Ee m 0 Ü ۰ E LISTEN 
iE CIS 0 0 localhost:953 D LISTEN 
2 ] : : [ : ۱ sess LISTEN 
tcpo 1 5 ۵ [ : ده‎ EEE LISTEN 


tcp6 localhost: 953 ssis LISTEN 


netstat -tln «netstat -tl تنفیذ الأمرين‎ 


۱۱ الخطوة‎ Y, Y? 


الخيار -t‏ يضاف إلى الأمر netstat‏ لعرض منافذ TCP‏ فقط. اما الخيار )- يحد التنفیذ إلى المنافذ ذات خدمة 


الاستماع. واخيراً 0- فهو يظهر عناوين شبكة عددياً: 


اساسیات لینکس 


5 netstat -ltn 


Active Internet connections (only servers) 


Proto Recv-Q Send-Q Local Address Foreign Address State 

TES 0 0 541909 و 5ق للا‎ 0 00:7 LISTEN 
TEP 0 0 OO. LESS ت0‎ LISTEN 
EÐ OOO 7+6 LISTEN 
8 5 510 5:0) 5 LISTEN 
LESS کا کہ‎ LISTEN 
COS Sie S. LISTEN 


tcp6 وم‎ LISTEN 


netstat -ltn تنفیذ الأمر‎ 


۳۵ 


T T Me 
2230 اساسیات لینکس‎ D 
NI 


المعمل الثالث عشر — النظام وحماية المستخدم 


oystem and User Security 


I7 


[Ee E] 


250 اساسيات لينكس‎ pM 


هذا كن نسل کله ر JUST‏ رها اسم وک کا ال مع اتسن الب ان کی 


النظامء وأیضاً عرض أي عملية من عملیات التشغيل الخاصة بأولئك المستخدمین. 


۲ حسابات المستخدم والمجموعة 


في هذه cagal‏ سوف نتعلم عن حسابات المستخدمين «user accounts‏ والملفات files‏ والأوامر 
5 التي عن طريقها يتم عرض display‏ معلومات حساب المستخدم user account‏ 


information 


۹ الخطوة ۱ 
یتم تعریف حسابات المستخدم user‏ والنظام system‏ في الملفين /etc/passwd‏ و Jetc/shadow‏ 


قم بعرض الاسطر العشرة الأولى من الملف 616/0865۷70 
head 0‏ 


ويكون التنفید مشابهه لما يلي: 


اساسیات لینکس 


:~$ head /etc/passwd 
982 5 31015105166615 5/2262 ٤+٥ 7٤0 
daemon:x:1:1:daemon:/usr/sbin:/bin/sh 
lox ase و‎ ۶ 822 51801013. 737 
23779 82759896 EYE ele : ۵ 
gynes 239-49859934 E SVE 2/۱2 71/۱17 / Svane 
games:x:5:60:games:/usr/games: /bin/sh 
man:x:6:12:man:/var/cache/man: /bin/sh 
lp:x:7:7:lp:/var/spool/lpd: /bin/sh 


mail:x:8:8:mail:/var/mail: /bin/sh 


news:x:9:9:news:/var/spool/news: /bin/sh 


$ 


تنفیذ الأمر head /etc/passwd‏ 
لاحظ أن هذا الملف يحتوي على نقاط Ja colon‏ على قاعدة بيانات 33S database‏ حسابات المستخدمين 


والنظام» والتي هي متوفرة available‏ على نظام التشغيل الحالي. 
هناك ثلاثة آنواع من الحسابات سیتم التطرق إليها في هذه المذكرة وهي: 


الأول - حساب المستخدم User accounts‏ حيث یتم إسناد حسابات المستخدمين user accounts‏ وذلك 
للمستخدمين العاديين للسماح لهم للوصول access‏ إلى نظام التشغيل operating system‏ ویعتبر حساب 


7 الذي يُستخدم لتسجیل الدخول إلى النظام هو خير مثال على حساب المستخدم العادي. 


الثاني - الحساب الرنيسي أو الجذر The root account‏ وهو حساب مستخدم خاص special user‏ 
account‏ افتراضیا لديه وصول access‏ وتحکم control‏ كامل على النظام. ويشار إليه أحیانا باسم 


حساب المستخدم الرئيسي .superuser account‏ 


الثالث - حسابات النظام System accounts‏ وتستخدم حسابات النظام من قبل نظام التشغيل operating‏ 
67 او الخدمات services‏ التي تدير العمليات running processes‏ علیه. هذه الخدمات لا يمكن 
تشغيلها حتى بواسطة المستخدم الجذر؛ وذلك بهدف أن یتم الحفاظ على النظام أکثر آمنا more secure‏ من 


خلال الحد limiting.‏ من الضرر damage‏ الذي يمكن ان تسببه حسابات خدمة التضمين comprised‏ 


YYA 


A‏ اساسیات لینکس 


service account‏ ولنفس السياق السابق فان حسابات النظام Y System accounts‏ تستخدم آبدا بشکل 


مباشر directly‏ من قبل المستخدمين العادیین regular users‏ 
٣٢‏ الخطوة Y‏ 
استخدم الأمر grep‏ لعرض تسجیل record‏ لحساب المستخدم :sysadmin‏ 


grep 1 ۵ 


ويكون التنفيذ مشابهه لما يلي: 


:~$ grep sysadmin 6 


:x:1001:1001:System Administrator...::/home/ :/bin/bash 


وب : 


تنفیذ الأمر grep‏ 


بسبب استخدام الأمر grep‏ فان التنفیذ output‏ بتضمن فقط معلومات حساب account information‏ 


لاسم مستخدم واحد .one username‏ 


طريقة آخری لاسترداد retrieve.‏ معلومات حساب مستخدم account information‏ هي عن طریق تشغیل 
الأمر التالي .getent passwd username‏ يتفوق الأمر ]0661 على الأمر grep‏ لأنه يستطيع الوصول 
إلى حسابات المستخدمین التي لم يتم تعریفها not defined‏ محلیا locally‏ وبعبارة «s x‏ الأمر 0616101 
قادر على الحصول على معلومات المستخدم user information‏ وذلك للمستخدمین users‏ المحتمل آنهم 
المعرفين defined‏ في خدمة دليل الشبكة LDAP d network directory servers‏ آووالا أو مجال 


.Active Directory Domain servers أو خدمة مجال الدليل الفعال‎ Windows Domain ويندوز‎ 


۳۳۹ 


A‏ ۱ اساسیات لینکس 
۳ الخطوة Y‏ 
استخدم الأمر 0616111 لاسترجاع معلومات حول الحساب :sysadmin‏ 
passwd sysadmin‏ 01661 


وينبغي أن یکون التنفيذ كما يلي: 


:~$ getent passwd sysadmin 


sysadmin:x:1001:1001:System Administrator,,,,:/home/sysadmin:/bin/ 
bash 


getent passwd sysadmin تنفیذ الأمر‎ 


ملاحظة: في النتيجة السابقة لم يتم العثور على أي حسابات للشبكة network accounts‏ وبالتالي فان التنفیذ 


Jetc/passwd المعروض هو تماما مثل النظر في الملف‎ output 


$5051 174 


يمكنك الاطلاع على الوثائق documentation‏ للحقول fields‏ في الملف /etc/passwd‏ مع الأمر التالي: 


man 5 0 


ویکون التنفیذ مشابهه لما يلي: 


۳۳۰ 


A‏ اساسیات لینکس 


PASSWD(5) File Formats and Conversions 
PASSWD(5) 


NAME 


passwd - the password file 


DESCRIPTION 


/etc/passwd contains one line for each user account. with 
seven fields 


delimited by colons (":"). These fields are: 
login name 
optional encrypted password 
numerical user ID 
numerical group ID 
user name or comment field 
user home directory 


optional user command interpreter 


Manual page passwd(5) line 1 (press h for help or q to quit) 


man 5 passwd تنفیذ الأمر‎ 


oS‏ آثناء عرض دلیل المستخدم «man page‏ اضغط على مفتاح Enter Ju y!‏ للانتقال الى السطر الذي 
يليه» أما للانتقال صفحة بعد أخرى فقم بالضغط على مفتاح مسافة .Spacepage‏ وأخيراً قم بالضغط على 


YY) 


2230 اساسيات لينكس‎ ES 
بالمجالات التالیة:‎ /etc/passwd الفاصلة تحدد ملف‎ 
account:password:UID:GID:GECOS :directory:shell 


وفيما يلي بتحليل لهذه الحقول الملف :Jetc/passwd‏ 


Jia account ۱‏ الحساب هو اسم المستخدم username‏ 

:password ۲‏ هذا الحقل أساساً يستعمل لتخزین كلمة المرور» والان یستعمل ایضا تخزین کلمات 
المرور ولکن في ملف etc/shadow‏ ویستعمل حرف × للدلالة على أن الخانة محجوزة لكلمة مرور 
وذلك بغرض اخفانها. 

SUID ٣۳‏ هو رقم هوية المستخدم. 

GID .٤‏ هو رقم هوية المجموعة. 

۰ 3008: یستخدم لتخزين الاسم الکامل full name‏ للمستخدم „User‏ 

:directory ٦‏ هو الدلیل الرئيسي home directory‏ للمستخدم» حيث یتم وضعه عند التسجیل 
الأول first logging‏ في النظام. 

Jis :shell field ٢‏ القشرة يحدد defines shell‏ القشرة للمستخدم « فمثلاً /bin/bash‏ تکون 
للمستخدم العادي «normal user‏ آما /sbin/nologin‏ فتكون للحساب المُستخدم من قبل النظام 


.Service أو خدمة‎ system 
o الخطوة‎ YY,Y,o 
0 اعرض معلومات حسابك أو حساب مستخدم محدد» وذلك باستخدام الأمر‎ 


0 


id root 


ويكون التنفيذ مشابهه لما يلي: 


اساسیات لینکس 


id‏ م576 


uid=1001 (sysadmin) gid=1001 (sysadmin) groups-1001 (sysadmin), 4(adm),27 
(sudo 


:^$ id root 


uid-0(root) gid-0(root) groups-0 (root) 


وم : 


id root «id تنفيذ الأمرين‎ 


التنفيذ السابق يُظهر هوية المستخدم الخاص بك برقم وأيضا باسم كما يلي: .uid21001(sysadmin)‏ 
ویعرض آیضا هوية المجموعة الرئيسية: (010-1001)5[/5301010» وجمیع المجموعات التي ينتمي إليها 
المستخدم وهي groups-1001 (sysadmin)‏ و 4(adm)‏ و .27(sudo)‏ إذن فان حساب المستخدم 


الخاص بك ينتمي إلى ثلاث lii groups ce saxa‏ 


ملف /etc/group‏ مع الملف /etc/passwd‏ یحددان determines‏ عضوية group sic pam‏ 
memberships‏ افتراضیاً يتم تحدید مجموعتك الأساسية your primary group‏ عن طریق مطابقة 
matching‏ رقم مجوعتك your GID‏ و الموجود في /etc/Dasswd‏ مع رقم المجموعة GID‏ الموجود في 
الملف Jetc/group‏ أيضا يتم تحدید أي عضوية لمجموعة ثانوية secondary group memberships‏ 


في الملف Jetc/group‏ 


OSA‏ المدخلات في الملف letc/group‏ هي: 


group name:password:GID:user list 


٦ الخطوة‎ ں٦‎ 


الأمر 0616111 يمكن من خلاله استرجاع retrieve‏ معلومات information‏ حول مُدخلات entries‏ 
قاعدة بيانات Jis‏ الملف Jetc/group‏ استخدم الأمر 061601 لاسترجاع المعلومات حول مجموعتي 


:۵0۱۸ sysadmin 


۳۳۳ 


اساسیات لینکس 


getent group sysadmin 


getent group adm 


ويكون التنفيذ مشابهه لما يلي: 


getent group sysadmin‏ وؤ ه: 


5۷ 52 07131 1 : x 1001 ۶ 


:~$ getent group adm 


adm:x:4:sysadmin 


تنفیذ الأمرين getent group adm «getent group sysadmin‏ 
المجموعات Groups‏ تستخدم من أجل التحکم في الوصول controlling access‏ إلى الملفات files‏ 


افتراضیاً أي ملف جديد تقوم بانشانه create‏ يكون مملوك owned by‏ من قبل مجموعتك الأساسية your‏ 
primary group‏ لإسناد ملكية أي ملفات جديدة قمت بإنشائها لأحد المجموعات الثانوية الخاصة بك your‏ 
secondary groups‏ قم باستخدام الأمر ۰06۷۷9۲0 الشكل الأساسي basic format‏ لهذا الأمر هو 
.newgrp group. name‏ يجب أن تكون عضوا في مجموعة من أجل استخدام الأمر .neWgrp.‏ في حين 


أن الأمر id‏ سيعرض اسم المجموعة GROUP. NAME‏ كمجموعتك الأساسية .your primary group‏ 


لتغيير مالك مجموعة group owner‏ وذلك لمجموعة من الملفات الموجودة existing files‏ التي يملكها 
المستخدم الخاص بك user owns‏ الاملاء يمكنك ذلك باستخدام الأمر .chgrp.‏ الشكل الأساسي basic‏ 


.chgrp group. name file name لهذا الأمر هو‎ format 


يجب أن 03S‏ عضوا في مجموعة j group member‏ ملكية الملف لمجموعة file group‏ 


.own the file المجموعة بالإضافة الى ملكيتك للملف‎ dl ownership 


رو 


اساسیات لینکس 


۷ الخطوة ۷ 


الأمران التاليان يوضحان الهوية الخاصة بك .groups ; whoami has‏ الأمر groups‏ يمكن أيضا أن 
يُستخدم للحصول على قائمة المجموعات list of groups‏ لمستخدم آخر ولیس بالضرورة أن يكون المستخدم 
الحالي للنظام. استخدم الأمران whoami‏ والأمر groups‏ لعرض معلومات بحسابك (sysadmin)‏ ثم بعد 
ذلك استخدم الأمر groups‏ فقط لعرض مجموعات المستخدم الرئيسي (root)‏ وذلك من دون عملية تبديل 


للمستخدم الحالي: 
whoami‏ 


groups 


groups root 


ویکون التنفیذ مشابهه لما يلي: 


:~$ whoami 
sysadmin 
:-$ groups 


sysadmin adm sudo 


:-$ groups root 


OSE E 7 


groups root «groups «whoami تنفیذ الأوامر‎ 


۳۳۵ 


س0 اساسیات لینکس 
۳٣‏ من فی هذا النظام 


في هذه المهمة» سوف نقوم بتنفيذ execute‏ بعض الأوامر لمعرفة من المستخدم 56 الذي قام بعملية تسجيل 


الدخول إلى هذا النظام logged into the system‏ 
1,۳۱ الخطوة ۱ 


استخدم الأمر who‏ للحصول على القائمة الحالية current list‏ من المستخدمين users‏ المتواجدين على 


النظام :on the system‏ 
who‏ 
ويكون التنفيذ مشابهه لما يلي: 


:~$ who 


sysadmin tty Ape ۵ی۱۹‎ 


:~$ 


تنفیذ الأمر who‏ 
تنفیذ الأمر who‏ هو أربعة أعمدة: 


e‏ اسم المستخدم Username‏ يظهر في العامود الأول اسم المستخدم» وهو sysadmin‏ في المثال 
أعلاه. 

o‏ النافذة الطرفية Terminal‏ يظهر في العامود الثاني معرف لنوع النافذة الطرفية Terminal‏ وهي 
tty‏ في المثال السابق. حيث أن لكل محطة Terminal‏ اسم منفصل separate name‏ يُستخدم 
من قبل المستخدم الرئيسي superuser‏ للسيطرة على العمليات control processes‏ 

١١ العامود الثالث هو لإظهار تاريخ ووقت تسجيل الدخول» وهو‎ Date/Time التاريخ/ الوقت‎ e 


Quod‏ ۱۶:۳۲ كما يظهر فى السطر الأول من التنفيذ أعلاه. 


۳۳۹ 


س0 اساسیات لینکس 


o‏ استضافة :Host‏ على الرغم من عدم وجود ناتج output.‏ بالعامود الرابع fourth column‏ في 
الوقت الحالي» الا انه يمكن أن يكون في ذلك العامود اسم أو عنوان IP‏ لمضيف host‏ محلي local‏ 
أو بعيد remote‏ الأشكال forms‏ التالية تشير إلى دخول محلي :local logins‏ (#:) أو (#.#:). 
آما خلاف ذلك» فقد يظهر مضیف بعید remote host‏ بالاسم اذا کان يدعم ذلك resolvable‏ أو 


من خلال عنوان P.‏ 
oy‏ نہ 


استخدم الأمر ۷۷ للحصول على عرض آکثر تفصیلا more detailed‏ للمستخدمين المتواجدين حالیا على 


:on your system النظام‎ 


تنفیذ الأمر W‏ یکون مشابهه لما يلي: 


:~$ w 
15817808 up 6 Cays, LS xum, 1 user, load average: 0.39, O0. 


USER JE FROM LOGING IDLE JCPU PCPU WHAT 


sysadmin console 02 4.00s 0-162 0۰005 w 


التنفیذ السابق هو ملخص summary‏ لمدة عمل النظام وعدد المستخدمین الذين قاموا بتسجيل الدخول 


٥‏ ومعدلات تحميل النظام system load averages‏ للفترات ١‏ و ٥‏ و Yo‏ دقيقة الماضية. 


ونری في المثال أعلاه إدخال لکل مستخدم مع اسم تسجيل الدخول «ogin name‏ واسم النافذة tty name‏ 
والمضيف host‏ ووقت تسجيل الدخول login time‏ ووقت الخمول idle time‏ و JCPU‏ (وقت وحدة 
المعالجة المركزية المستخدمة من قبل الوظائف الخلفیث) و POPU‏ (وقت وحدة المعالجة المركزية المستخدمة 


من قبل العملية الحالیة) وما الأوامر المنفذة على سطر الأوامر الحالي. 


۲۷ 


AW‏ اساسیات لینکس 


في هذه المهمة سوف تتعلم كيفية الوصول إلى حساب المستخدم الجذر بعدد من طرق مختلفة, 


حساب المستخدم الجذر root‏ هو حساب مميز special‏ في نظام التشغیل لينكس؛ حيث أن له صلاحيات غير 
محددة للسيطرة control‏ والوصول access‏ على كامل النظام. الجدير بالذكر أن قيمة رقم هوية المستخدم 


UID‏ والتي تكون بقيمة الصفر؛ هي التي تمنح هذه السلطة authority‏ ولیس اسم المستخدم. 

بشکل عام» Y‏ يعتبر تسجیل الدخول login‏ إلى النظام بصفة مستخدم جذر root user‏ تدريب جید. وبشکل 
e 5 9 3‏ 

خاص ينطبق هذا بالکامل على البيئة الرسومية graphical environment‏ 

تستطیع الوصول access.‏ الى حساب الجذر root user‏ باستخدام asi‏ الأمرين su‏ أو .sudo‏ 


الأمر راو عادة ما یستخدم لتبدیل المستخدمين switch users‏ وذلك sad‏ قشرة جديدة new shell‏ کمستخدم 
آخر another user‏ بشکل افتراضي يكون التحويل إلى المستخدم الجذر root user‏ بالإضافة إلى تبدیل 
المستخدمین؛ یستخدم ایضا الأمر Lace su‏ نحتاج إلى تنفيذ execute‏ سلسلة من الأوامر series of‏ 


5 باسم المستخدم الجذر. 


في المقابل يستخدم الأمر sudo‏ لتنفيذ execute‏ أمر واحد single command‏ باسم المستخدم الجذر؛ 
وذلك بکتابة الأمر مع sudo‏ كما يجب أن يتم تكوين configure‏ الأمر sudo‏ من قبل المستخدم الجذر قبل 


ان يتمكن المستخدم العادي Ordinary user‏ من استخدامه. 
343 الخطوة ١‏ 


لاعداد set up‏ الأمر sudo‏ للمستخدمين العاديين tregular users‏ استخدم الأمر visudo‏ والذي يتطلب 
requires‏ وصول الجذر access.‏ ]۰۲00 حيث سيفشل الأمر السابق عند تنفيذه بواسطة المستخدمين العاديين. 


حاول attempt.‏ تكوين الوصول configure access‏ إلى الأمر :sudo‏ 


۳۳۸ 


اساسیات لینکس 


visudo 


ويكون التنفيذ مشابهه لما يلي: 


3-72 visudo 


visudo: /etc/sudoers: Permission denied 


visudo: /etc/sudoers: Permission denied 


و : 


تنفیذ الأمر visudo‏ 


یظهر في التنفيذ output.‏ أن الأمر visudo‏ فشل لأنه حاول modify dai‏ الملف «etc/sudoers‏ وهو 
ملف لا یستطیع المستخدمین العادیین regular users‏ تعدیله بسبب الأذونات permissions‏ حیث یتحکم 
5 هذا الملف بالوصول access.‏ إلى الأمر sudo.‏ وينبغي ألا يتم تعدیله مباشرة ولکن باستخدام 


visudo الأمر‎ 


23 خی ؟ 


Ja‏ المستخدمين switch users‏ إلى حساب المستخدم الجذر qoot user‏ واعطي كلمة سر الجذر 


3 عند الطلب: 


Su - 


(Enter the password: ۱۵۱۱۵0 123[ 


ويكون التنفيذ مشابهه لما يلي: 


Password: 


تنفیذ الأمر sudo‏ 


۳۳۹ 


س0 اساسیات لینکس 


رمز الشرطة أو الواصلة " - " الذي يُكتب بعد الأمر SU‏ هو اختصار abbreviation‏ إلى الخیار -l‏ ء وهو 
الأمر الذي یجعل من تسجيل الدخول login.‏ والذي يتم بواسطة الأمر SU‏ هو تسجيل دخول كامل complete‏ 
7 وذلك بتنفيذ execute‏ برامج تسجیل دخول belong (s login scripts‏ إلى المستخدم الجذر 


.root user 


بدون رمز الشرطة dash‏ " " أو الخیار ]- فان الأمر su‏ سيبدل switch‏ هوية المستخدم الخاص بك your‏ 
«user identity‏ ولکنه لن ینفذ execute‏ البر امج النصية لتسجیل الدخول login scripts‏ لمستخدم جدید 
user‏ . والذي یمکن أن يُسبب بعض المشاکل وخصوصاً عند التبدیل إلى حساب الجذر account‏ ۲001. 
في معظم الحالات والخاصة بتبدیل المستخدمین switch users‏ فأنت ترغب performed euis‏ عملية 
تسجیل دخول کامل complete login‏ بحیث یتم تهيئة äis‏ المتغیرات environment variables‏ 


والوظائف functions‏ والأسماء المستعارة aliases‏ لانشاء مستخدم جدید ومن ثم اطلاقه initialize‏ 


٣٣ لفط‎ ۴ 


والآن بعد أن قمت بتسجيل الدخول logged in‏ باسم المستخدم الجذر root user‏ يجب أن تكون قادر على 


تنفيذ execute‏ أوامر التکوین configure‏ والخاصة بالوصول access‏ إلى الأمر :Sudo‏ 


visudo 


ويكون التنفيذ مشابهه لما يلي: 


تنفیذ الأمر visudo‏ 


۳:۰ 


اساسیات لینکس 


٤ الخطوة‎ 4 


لتمكين enable‏ عملية الوصول الأساسي basic access‏ لاستخدام الأمر 00/ا5؛ يجب إضافة add‏ السطر 
التالي (sysadmin ALL=(ALL) ALL)‏ في الملف /etc/sudoers‏ والذي تقوم بتحريره الآن. بما آنك في 
المحرر أ۷ افتراضياًء اكتب ما يلي: 

ماذا اکتب المعنی 

6 وضع الأوامر: الذهاب إلى السطر الأخير. 

0 وضع الادراج: لادراج سطر جدید تحت السطر الحالي. 

sudo الدخول مسموح للوصول إلى نظام‎ | sysadmin ALL=(ALL) ALL 


ESC‏ للخروج والعودة إلى وضع الاوامر. 


wq‏ لحفظ التغییرات والخروج من الملف بالكامل. 


جدول لتعدیل sudo‏ 


fincludedir /etc/sudoers.d 


Sysadmin ALL-(ALL) ALL 


= NSERU S 


sudo »4 تنفیذ‎ 


إذا قمت بكتابة ما سبق من بيانات data‏ في الملف بشکل صحیح correctly‏ فستعود مرة آخری إلى موجه 


الأوامر prompt‏ في قشرة .shell‏ 
ولكن وفي بعض الأحيان عند الانتهاء التحرير تظهر رسالة ماذا الآن؟ عندها اضغط على مفتاح الادخال 


۲ للاطلاع على الخيارات الخاصة بك. ومن المستحسن أن تكتب حرف للخروج دون حفظ التغييرات 


على الملف ۰8۱006۲5 ثم قم بتكرار هذه الخطوة مرة أخرى. 


اساسیات لینکس 


٥ الخطوة‎ ٥ 


قم بالعودة إلى حساب sysadmin‏ للتحقق من أن الأمر sudo‏ یوفر الوصول للجذر «root access‏ وذلك 


بالخروج من حساب الجذر root‏ عن طريق کتابة الأمر التالي: 


exit 


ويكون التنفيذ مشابهه لما يلي: 


تنفيذ الأمر exit‏ 


٦ الخطوة‎ ٦ 


حاول عرض الأسطر الثلاثة الأولى من الملف detc/shadow‏ وهو الملف الذي يحتوي على كلمات السر 
المشفرة encrypted passwords‏ ومعلومات حول عمر كلمة السر password aging‏ (إلى متى تكون 


كلمة مرور صالحة): 


head -3 - ۷ 


ويكون التنفيذ مشابهه لما يلي: 


:~$ head -3 /etc/shadow 


head: cannot open ^/etc/shadow' for reading:Permission denied 


head -3 /etc/shadow الأمر‎ xài 


۳:۲ 
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لاحظ ظهور رسالة خطأ message‏ ۲ عند استخدامنا للأمر السابق؛ وذلك لأن حساب المستخدم 
0 ليس لديه الصلاحية لعرض view‏ هذا الملف» حيث يمكن عرض هذا الملف من قبل المستخدم 


.oot user الجذر‎ 
۷ الخطوة‎ ٧ 


لاحظ أن الأذونات permissions‏ في ملف /etc/shadow‏ تشير إلى أن أعضاء مجموعة shadow‏ 


view the file لرؤية الملف‎ permission فقط يكون لديهم الإذن‎ group 
ls - 01 


ضع في اعتبارك أنه يمكن للمستخدم الجذر root user.‏ عرض أي ملف. ويرجع ذلك إلى أن حساب الجذر 
لديه امتيازات خاصة special privileges‏ تتجاوز transcend‏ أذونات الملفات العادية regular file‏ 


15ء 


:-$ وا‎ -l /etc/shadow 


-rw-r----- 1 root shadow 838 Mar 14 2016 /etc/shadow 


$ 


ls -L/etc/shadow تنفیذ الأمر‎ 


۸ الخطوة ^ 


استخدم الأمر sudo‏ لعرض الأسطر الثلاثة الأولى من ملف Jetc/shadow‏ 


sudo head -3 /etc/shadow 


(Enter the password: netlab1 23} 


ویکون التنفيذ مشابهه لما يلي: 


٣٢ 
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:~$ sudo head -3 7 


[sudo] password for sysadmin: 


root:$6$T3W2rbrtSN/2JrtlEzQ8TqOvxWkYjEplIf3tCbPOyFwU7ZYkToosXBA4AGmtbO. 
W6f8Gb7Vmihnj76yZezNPwMbTGOQFs5Kx1:16874:0:99999:7::: 


€ و v g 159.3 8(0 8 9JOIO Og) 2 TB‏ 5 22677 اه 
۶ ۰ 0 و bims”‏ 
$ 


(Enter the password: netlab123) «sudo head -3 /etc/shadow تنفیذ الأمر‎ 


ملاحظة هامة: كلمة السر التي قمت بكتابتها هي لحساب المستخدم sysadmin‏ الخاص بك وليست لحساب 
الجذر root account‏ عندما یتم عمل التكوين configured‏ للأمر sudo‏ للحساب الخاص بك فانك لا 


تحتاج إلى معرفة كلمة سر الجذر root password‏ لتشغیل الأمر sudo‏ کالمستخدم الجذر user‏ ۲001. 


— Me 
230 اساسیات لینکس‎ ^W 
inc d 


اد هه رب تن بان 


Creating a User 


m 


AW‏ اساسیات لینکس 


١‏ مقدمة 


هذا هو المعمل الرابع عشر: إنشاء مستخدم. عن طريق أداء هذا المعمل» سوف نتعلم كيفية إنشاء حساب لمستخدم 
جدید» وإنشاء كلمة مرور أولية لهذا الحساب» وإجراء تعديلات أخرى على المستخدم مثل جعله عضوا في 
مجموعة ثانوية. 
في هذا التمرین» سوف نقوم بالمهام التالية: 

٭ إنشاء مستخدم جديد مع الأمر .useradd‏ 


.passwd تعيين وإعادة تعيين كلمة مرور المستخدم مع الأمر‎ e 


۰ إجراء تغييرات على حساب المستخدم مع الأمر .usermod‏ 


في هذه المهمة» سنقوم بانشاء حسابات create an accounts‏ لمجموعة group‏ ولمستخدم .USer‏ 


حسابات المجموعة group accounts‏ مفيدة وذلك لتعيين الأذونات assign permissions‏ على الملفات 


المشتركة shared files‏ من قبل مجموعة من المستخدمین .group of users‏ 


حسابات المستخدمین user accounts‏ في توزیعات لینکس مبنية على based upon‏ رید هات Red Hat‏ 
مثل توزيع «CentOS.‏ حیث تبدأ مع أول معرف للمستخدم (UID)‏ بالرقم ۰۰۰۰ رمز المستخدم User ID‏ 
التالي هو ۵۰۱ ela‏ جرا. العدید من التوزیعات الأخرى الحديثة تمیل إلى أن يكون رمز المستخدم الأول first‏ 
UID‏ هو الرقم ۰۱۰۰۰ والثاني ۱۰۰۱ وهلم Jos‏ 

عند أدارة حسابات managing accounts‏ لأنظمة متعددة tmultiple systems‏ فمن المستحسن أن تکون 
مصادقة الخادم مستندة إلى الشبكة network-based authentication server‏ حيث یمکن انشاء 


الحسابات created an accounts‏ دفعة واحدة ولکن تستخدم على أجهزة متعددة .many machines‏ 


والا فستکون إدارة الحسابات المتعددة managing multiple accounts‏ على آلات متعددة on multiple‏ 


٤. 


س0 اساسیات لینکس 


5 تحدیا؛ حيث سيكون من الصعب التأکد ensure‏ من ان المستخدم USET‏ وجمیع المجموعات 
all the groups‏ التي تنتمي إلى الكل لديها نفس قيمة GIDss UIDs‏ على جميع الالات on all‏ 


.machines 


وثمة مسألة آخری مع حسابات الجهاز المتعددة multiple machine accounts‏ وهي 43 من الصعب 
difficult‏ محاولة الحفاظ على کلمات السر passwords‏ لکل حساب متزامن account synchronized‏ 


.across all machines عبر كافة الأجهزة‎ 


à jl‏ الحسابات managing accounts‏ للمستخدمين المحليين local users‏ لا تزال مفيدة من قبل الالات 
الفردية individual machines‏ حتى إذا کان لدیهم إمكانية الوصول access‏ إلى مصادقة الخادم المستندة 
إلى الشبكة network-based authentication server‏ في هذا التمرین» سوف نقوم بادارة المجموعة 


.user accounts وحسابات المستخدمین‎ local group المحلية‎ 


١ الخطية‎ 12,1 


من أجل إدارة administer‏ حسابات المستخدمين والمجموعات «ser and group accounts‏ سوف 


تحتاج إلى تبديل المستخدمين switch users‏ إلى حساب الجذر root account‏ باستخدام الأمر التالي: 


Su - 


(Enter the password: netlab123) 


ويكون التنفید مشابهه لما يلي: 


Password: 


تنفیذ الأمر - SU‏ 


۳:۷ 


A‏ اساسیات لینکس 
٣۲‏ الخطوة ۲ 
استخدم الأمر groupadd‏ لإنشاء مجموعة create a group‏ تسمی research‏ 


0۲۵۱/۵200 -r research 


ویکون التنفید مشابهه لما يلي: 


:~# | groupadd -r research 


Ded 


groupadd -r research الأمر‎ 3s 


إن استخدام الخيار ۲- مع الأمر السابق للمجموعة التي تم اضافتها وهي research‏ یجعل معرف المجموعة 
GID‏ في النطاق المحجوز reserved range‏ بين ۹۹۹-۱. يتم تعيين معرفات مجموعة (GIDS)‏ تلقائیا 
automatically‏ مع قيمة أقل من اقل قيمة المعرف UID‏ للمستخدم العادي مع هذا الخيار. نقطة أخرى وهي 
أن الأمر groupadd‏ يقوم بتعدیل الملف /etc/group‏ والذي يتم تخزين store‏ المعلومات حساب المجموعة 


.43 group account information 


يمكن استخدام الأمر groupmod‏ مع خيار 0- لتغيير اسم هذه المجموعة group name‏ أو الخيار -g‏ من 
أجل تغيير المعرف GID‏ لهذه المجموعة. LÍ‏ لحذف المجموعة فاستخدم الأمر 0۲0۱1006۱ طالما أنه لم يتم 


جعلها المجموعة الأساسية primary group‏ لمستخدم .USer‏ 


۳۵ ۴۹ ۷۷ 


استخدم الأمر ]616۳و لاسترجاع retrieve.‏ معلومات من قاعدة بيانات أو ملف حول المجموعة الجديدة: 


getent group research 


۳:۸ 


اساسیات لینکس 


يجب أن يظهر التنفيذ مشابه لما يلي» على الرغم من أن معرف المجموعة GID‏ الذي تم تعيينه assigned‏ قد 


يكون مختلف في الجهاز الذي تستخدمه: 


# getent group research 


126553120112: ۰97 


تنفيذ الأمر getent group research‏ 
والآن بعد أن تم انشاء مجموعة «research‏ فيمكنك إضافة مستخدمین حاليين existing or users‏ أو جدد 
new‏ كأعضاء member‏ في هذه المجموعة. لاضافة مستخدم إلى مجموعة ثانوية يجب استخدام أمر التعدیل 
على مستخدم usermod‏ ثم الخيار 3 للإضافة وأخیراً الخیار -G‏ والخاص بالمجموعات الثانوية. لاحظ أنه 
في حالة وجود أكثر من مجموعة ثانوية نريد إضافة المستخدم لها فيجب إضافة فاصلة " , " وذلك للفصل 
separated‏ بين تلك المجموعات. LÍ‏ عند استخدام الخيار -G‏ بدون الخيار ج فسیتم حذف جميع المجموعات 


الثانوية السابقة وإضافة الجديدة. 


يجب أن يحتوي خيار -G‏ مع الأمر usermod‏ على قائمة مفصولة بفواصل لجميع المجموعات الثانوية التي 
ينتمي إليها المستخدم. وعند استخدام usermod‏ مع الخيارات -a‏ وو)- عندها فقط المجموعة الجديدة سوف 
تحتاج إلى أن تكون محددة specified.‏ وسوف تضاف إلى عضوية مجموعة group memberships‏ 


.existing secondary ثانوية موجودة‎ 


٤ الخطوة‎ 5 


استخدم usermod mY!‏ لإضافة المجموعة research‏ كمجموعة ثانوية secondary group‏ للمستخدم 


:sysadmin 


usermod -aG research sysadmin 


ویکون التنفيذ مشابهه لما يلي: 


۳:۹ 


س0 اساسيات لينكس 


usermod -aG research sysadmin‏ چه: 


HI 


usermod -aG research sysadmin تنفيذ الأمر‎ 


المستخدمين الذين قاموا بتسجيل دخول logged into‏ تفاعلي actively‏ في النظام system‏ لن یکونوا 
قادرين على استخدام عضوية memberships‏ أي مجموعة جديدة tnew group‏ الا في المرة القادمة 


ui‏ بقومون فیها بنسجیل الدخول الی النظام. 


٥ الخطوة‎ ٥ 


هناك العديد من الأوامر التي يمكن استخدامها للتحقق verify‏ من عضوية membership‏ المجموعة الجديدة 

new group‏ استخدم الأوامر التالية «dd «groups‏ 061604 للتحقق من عضويات المستخدم 
:sysadmin's‏ 

groups sysadmin 

id sysadmin 


getent group research 


يجب أن يظهر إخراج الأوامر السابقة بالشكل التالي: 


اساسیات لینکس 


:~# groups sysadmin 
sysadmin : sysadmin adm sudo research 
:~# id sysadmin 


uid=1001 (sysadmin) gid=1001 (sysadmin) groups=1001 (sysadmin) ,4(adm),27 
(sudo), 999 (research) 


# getent group research 


research:x:999:sysadmin 


Dod 


تنفيذ !5 4» getent group research «id sysadmin «groups sysadmin‏ 
الأمر useradd‏ يقوم بانشاء create‏ حساب مستخدم «new user account 23s‏ وفي التوزيعات المبنية 
على رید هات Red Hat‏ يُستخدم للمجموعة الجديدة new group‏ لهذا المستخدم USET‏ وسيتم تسمية هذه 
المجموعة الجديدة باسم المستخدم وستكون المجموعة الأساسیة primary group‏ لذلك المستخدم. 
أيضاً تستخدم التوزیعات المبنية على ريد هات Red Hat-based distributions‏ ما یعرف باسم عضو 
المجموعات الخاصة «User Private Groups - UPG‏ والتي تعني أن كل مستخدم هو عضو أساسي 
primary member‏ في المجموعة الخاصة به. 
Li‏ التوزيعات distributions‏ التي لا تستخدم التقنية السابقة UPG‏ فان كل المستخدمين الجدد all new‏ 
users‏ ینتمون إلى belong to‏ مجموعة المستخدمین Users group‏ کمجموعتهم الرئيسية primary‏ 


.group 


٦ الخطوة‎ ٦ 


انشئ مستخدم جدید new user‏ یسمی «student‏ بحيث يكون عضو ثانوي member‏ 600۳02۲۷ في 
مجموعة research‏ و عضو أساسي primary member‏ في مجموعة خاصة به. استخدم التعلیق Linux‏ 
Student‏ ليبدو وكأنه الاسم الکامل full name‏ للمستخدم عند القيام بتسجیل الدخول في الواجهة الرسومية 


:-۲ الخاص به سیتم إنشاءه بواسطة خیار‎ home من أن الدلیل‎ al graphical login 


Yo) 


A‏ اساسیات لینکس 


useradd -G research -c 'Linux Student' -m student 


ويكون التنفيذ مشابهه لما يلي: 


:~# useradd -G research -c 'Linux Student' -m student 


Dod 


useradd -G research -c 'Linux Student -m student تنفیذ الأمر‎ 


يتم تخزین stored‏ معلومات حساب المستخدم user's account information‏ في الملفين 
0 و /etc/shadow‏ ويمكن الاطلاع على معلومات المجموعة لمستخدم user's group‏ 


Jetc/group و‎ /etc/passwd في الملفين‎ information 


V الخطوة‎ ٧ 


باستخدام الأمر 0161ء اعرض أعضاء مجموعة group members‏ والمسماة باسم research‏ مرة 

أخرى» ثم استخدم نفس الأمر السابق getent‏ ولکن لعرض أعضاء مجموعة «student.‏ وأخيراً قم بعرض 
قاعدتي البيانات passwd‏ و shadow‏ للمستخدم :student‏ 

061661 group research 

getent group student 

getent passwd student 


getent shadow student 


ويكون التنفيذ مشابهه لما يلي: 


اساسیات لینکس 


:~# getent group research 
research:x:999:sysadmin,student 

:~# getent group student 
student:x:1002: 

:~# getent passwd student 


student:x:1002:1002:Linux Student:/home/student:/bin/sh 


:~# getent shadow student 


s 1 81.6902 2(0)8 99 999S 78S 8 €‏ 041015 ندع 


Dvd 


«getent passwd studen «getent group student «getent group research تنفیذ الأوامر‎ 


getent shadow student 


یظهر في التنفيذ السابق أن كلا المستخدمین sysadmin‏ و student‏ هما عضوان ثانویان secondary‏ 


5 في مجموعة research‏ 


معرف المجموعة GID‏ لمجموعة student‏ بطابق matches‏ الحقل الرابع fourth field‏ من المعلومات 
7 الموجودة في الملف passwd‏ وهذا هو ما يجعل student‏ عضو رنيسي primary‏ 


.Student لمجموعة‎ ۲ 


وأخيراًء علامة التعجب " ! " والتي تظهر 20066۲6 عند تنفيذ الأمر getent shadow student‏ وتحدیداً 
في حقل كلمة المرور password field‏ وهو الحقل الثاني من الملف shadow‏ فهي للتوضیح أنه لم يتم 


Student للمستخدم‎ password كلمة المرور‎ set up تعيين‎ 


۸ الخطوة‎ ٨ 


استخدم الأمر passwd‏ من أجل تعيين set‏ کلمة المرور password‏ للمستخدم Student‏ وهي 
(161]30123)ء ثم بعد ذلك قم بعرض تلك الكلمة والتي من المفترض أن تكون قد آدخلت في الملف shadow‏ 


:student للمستخدم‎ 


اساسیات لینکس 


passwd student 
Enter new UNIX password: netlab123 
Retype new UNIX password: netlab123 


getent shadow student 


تنفیذ الأمر getent shadow student‏ يُظهر کلمة المرور للمستخدم student‏ والموجودة في قاعدة 


البيانات /etc/shadow‏ ولكن بشكل مشفرء كما هو واضح في الحقل الثاني وتحدیداً بعد اسم المستخدم: 


:~# passwd student 
Enter new UNIX password: 


Retype new UNIX password: 


passwd: password updated successfully 


:~# getent shadow student 


student :$6$pIEEdvAX$GBo0beYhojL3/vDrOP2UAQR6UVCWMZXXMPqImMREJWw/50R2WT 
tM6dH3H83Vj rmG6hGd9ux2I9FQFWQLtg3/:16902:0:99999:7::: 


Dod 


Enter new «Enter new UNIX password: netlab123 «passwd student تنفیذ الأوامر‎ 


getent shadow student ‘UNIX password: netlab123 


848 الخطوة 4 


وجود کلمة مرور password‏ للمستخدم user‏ لا يعني بالضرورة أنه قام بأي تسجيل الدخول logged‏ 


into‏ للنظام. استخدم الأمر last‏ لمعرفة ما إذا كان المستخدم student‏ قد قام باي تسجیل دخول في النظام: 


Last 


last student 


اساسیات لینکس 


يجب أن یظهر في التنفيذ أن المستخدم sysadmin‏ فقط هو الذي قام بتسجيل الدخول logged in.‏ للنظام» 


Ul‏ المستخدم student‏ فيجب ألا يظهر له أي تسجيل دخول للنظام: 


sam last 


sysadmin console Mon Apr 11 19:08 still logged in 


sysadmin console Mon Apr LL 19:08 = 189:08 (00:00) 


wtmp begins Mon Apr 11 18:25:26 6 


last student‏ ام 


wtmp begins Mon Apr 11 18:25:26 2016 


Dvd 


last student «last تنفیذ الأمرین‎ 


وهناك آیضا أمر clastb.‏ والذي يعمل بشكل مشابه للامر dast‏ الا أنه يُظهر محاولات attempts‏ تسجيل 


.bad or failed الفاشلة أو الغير صحيحة‎ [og in الدخول‎ 


إذا لم تعد ترغب في وصول access‏ المستخدم student‏ ودخوله على النظام system‏ استخدم الأمر 
0 والخاص بالتعدیل على المستخدمين ثم الخیار -L‏ والذي بستعمل لحجب أو قفل الحساب lock‏ 
the account‏ وأخیراً اسم المستخدم student‏ ويمكن فك الحجب unlocked‏ بنفس الأمر السابق ولكن 


.usermod -U student كما يلي‎ -U مع الخيار‎ 


الحل الدائم permanent solution‏ لمنع الوصول preventing access‏ للنظام من قبل الحساب الجديد 
والذي Gai‏ بإنشائه وهو student‏ هو حذف delete‏ ذلك الحساب عن طريق أحد الطرقتين التاليتين؛ الأولى 
مع الأمر userdel student‏ والذي يقوم بحذف المستخدم فقط أو الثانية وهي باستخدام نفس الأمر السابق 
ولكن بإضافة الخيار -r‏ كما يلي -r student.‏ 15610©1ا. حيث أن إضافة الخيار -r‏ مع الأمر userdel‏ يقوم 
بحذف حساب المستخدم os deleting the user's account‏ إزالة removes‏ الدليل الرئيسي للمستخدم 


.mail وأيضاً البريد‎ user's home directory 


EM 
اساسيات لينكس‎ ^W 


۰ الخطوة ۱۰ 
احذف الحساب student‏ مع إزالة الدلیل الرئيسي للمستخدم وايضاً البرید: 


۱۱86۲۵6۱ -r student 


تنفيذ الأمر ينبغي أن يبدو كما يلي: 


userdel -r student‏ ه: 


Dod 


userdel -r student تنفيذ الأمر‎ 


Yo" 


9 IN i . " Me 
2:50 اساسیات لینکس‎ D 
Ni 


امسل ااکاسن عقر = الملكيات: و کات 


Ownership and Permissions 


2230 اساسیات لینکس‎ pM 


الملکیات ownerships‏ وأذونات permissions‏ الملفات والدلائل. 


ه عرض وفهم الأذونات للملفات والمراجع. 
ه استخدام الأمر chmod‏ لتغيير الأذونات. 


.chgrp. chown تغيير الملكيات مع الأوامر‎ o 
أذونات الملفات والملكيات‎ ٢ 


في هذه المهمة» سوف تقوم بانشاء create‏ الملفات والدلائل «files and directories‏ ثم عرض view‏ 


وتعيين set‏ الأذونات والملكيات permissions and ownerships‏ 
Y,‏ الخطوة ۱ 
انشئ اثنين دليلين وملفين في الدليل /tmp‏ كما هو موضح: 


cd /tmp 
mkdir priv-dir pub-dir 
touch priv-dir/priv-file 


touch pub-dir/pub-file 


ویکون التنفيذ مشابهه لما يلي: 


اساسیات لینکس 


:-$ cd ۵ 


$ mkdir priv-dir pub-dir 


$ touch priv-dir/priv-file 


$ touch pub-dir/pub-file 


$ 


touch pub-dir/p «touch priv-dir/priv-file «mkdir priv-dir pub-dir «cd /tmp تنفیذ الأوامر‎ 


ub-file 


۲ الخطرة‎ Yo, Y, Y 


:directories contents محتویات الدلائل‎ view اعرض‎ 


ls -l priv-dir 


ls -l pub-dir 


ويكون التنفيذ مشابهه لما يلي: 


$ ls -l priv-dir 

total 0 

-rw-rw-r-- 1 sysadmin sysadmin 0 Apr 11 21:26 priv-file 
$ ls -l pub-dir 


toral 0 


-rw-rw-r-- 1 sysadmin sysadmin 0 Apr 11 21:27 pub-file 
$ 


تنفیذ الأمرين -l pub-dir «ls -L priv-dir‏ کا 


س0 اساسیات لینکس 


الآن سنشرح النتيجة 6-016 لام 21:27 11 -rw-rw-r-- 1 sysadmin sysadmin 0 Apr‏ كما يلي: 


ان الخانة الأولى first character‏ من السطر تشير إلى نوع type‏ هذا الكائن. ولنبدأ بعلامة الشرطة أو 
الواصلة ) - ) hyphen‏ وهي موجودة في بداية تفاصیل الملف السابق وتعني آن هذا الکائن هو ملف عادي 
regular file‏ اما |ذا كانت الخانة الأولى هي الحرف ‏ فهذا يشير إلى أن الكائن هو من نوع دلیل «directory‏ 
آما الحرف [ فهو للدلالة على ارتباط رمزي «symbolic link‏ وحرف b‏ فهو لملف AES‏ الجهاز block‏ 
«device file‏ ونجد ان الحرف c‏ هو ملف خانة الجهاز «character device file‏ وحرف p‏ هو ملف 


الأنابیب pipe file‏ و 5 هو ملف برنامج الاستماع „Socket file‏ 


العلامة نوع الکائن 

علامة الشرطة أو الواصلة ) - ( .hyphen‏ ملف عادي. 

directory دلیل‎ d الحرف‎ 

الحرف ]. ارتباط رمزي .symbolic link‏ 

الحرف b‏ لملف كتلة الجهاز .block device file‏ 
الحرف 6. ملف خانة الجهاز character device file‏ 
الحرف p‏ ملف الأنابيب pipe file‏ . 

الحرف 5. ملف برنامج الاستماع „Socket file‏ 


جدول یوضح نوع الکائن 


بعد الخانة الأولى لننتقل إلى الخانات التسعة nine characters‏ التالية وهي qw-rw-r--‏ تصنف تلك الخانات 
إلى ثلاث مجموعات «three groups‏ كل مجموعة تتكون من ثلاثة خانات «three characters‏ أول 
مجموعة في المثال السابق هي (rW-)‏ وتعني آذونات المستخدم المالك user owner's permissions‏ 
للکائن» آما المجموعة التي تليها وهي (rw-)‏ فتعني أذونات مجموعة المالكين group owner's‏ 


5 للکائن (المجموعة التي ينتمي إليها المستخدم المالك للملف)» وأخیراً المجموعة الثالثة وهي )- 


۳۹۰ 


PS‏ اساسیات لينكن 


everyone else's آنونات أي شخص آخر‎ ) others permissions وتمثل أذونات الآخرين‎ (r- 


(permissions 


ولكن ما معنی تلك الرموز؟ يدل الحرف ۲ على إذن «read permission żel jill‏ ثم بعد ذلك الحرف W‏ والذي 
يدل على إذن الكتابة write permission‏ واخيراً الحرف x‏ والذي يشير إذن التنفيذ execute‏ 
«permission‏ أما إذا وجدنا علامة شرطة - موجودة في أحد تلك الخانات التسعة السابقة وهي --۲۷۷-۲۷۷-۲ 
فهذا يشير الى سحب تلك الأذونات السابقة منه (سوءاً کان للمالك ورمزه را أو للمجموعة ورمزها و أو للآخرين 


ورمزهم 0). 


الآن نتطرق في الحديث عن الحقل الثاني وهو رقم حساب الارتباط clink count number‏ وکما نلاحظ في 


المثال السابق أنه رقم (1) وهو يشير إلى عدد الملفات files numbers‏ المرتبطة linked‏ بهذا الملف file‏ 
بعد ملفات الارتباط نری المستخدم المالك user owner‏ للملف file‏ وهو في المثال السابق .sysadmin‏ 


بعد ذلك نجد المجموعة التي ينتمي اليها المستخدم المالك وهي مجموعة المالكين group owner‏ للملف file‏ 


والموجودة في المثال السابق هي .Sysadmin‏ 

آما النقطة التالية فهي حجم الملف size of the file‏ وهو في المثال السابق (0). 

بعد الحجم نشاهد التاريخ والوقت date/time‏ لآخر تعديل last modified‏ تم على الملف. 
واخیراً نجد اسم الملف file name‏ 

Y الخطوة‎ ٣ 


إذا كنت تريد أن تجعل دلیل ما أکثر خصوصية private‏ ۵ استعمال الأمر chmod‏ لإزالة الأذونات 


remove 5‏ عن ذلك الدليل. استخدم الأمر chmod‏ لإزالة آذونات الاخرين من قراءة وتنفیذ: 


Yi 


اساسیات لینکس 


-ld priv-dir/‏ کا 
chmod o-rx priv-dir/‏ 


ls -ld priv-dir/ 


يُظهر الأمر الأخير أن الآخرين ليس eel‏ إذن permission‏ أو الوصول access‏ إلى الدليل :priv-dir‏ 


$ ls -ld priv-dir/ 
drwxrwxr-x 2 sysadmin sysadmin 4096 Apr 11 21:26 


5 chmod ور ی‎ dA 


$ ls -ld priv-dir/ 


drwxrwx--- 2 sysadmin sysadmin 4096 Apr 11 21:26 
$ 


تنفيذ الأوامر ls -ld priv-dir/ «chmod o-rx priv-dir/ «ls -ld priv-dir/‏ 
يمكنك استخدام الأمر chmod‏ لتعدیل أذونات الآخرين others‏ باستخدام الرمز الذي یمثلھم وهو الحرف 0؛ 
متبوع بأحد العلامات الثلاث وهي علامة زائد + لاضافة الأذونات» أو علامة ناقص - لإزالة الأذونات» وأخيراً 
علامة يساوي = والتي لها طريقتين في العمل» الأولى مع التحديد للجميع 2 حیث تقوم باعطاء الصلاحيات 
المذكورة مع الأمر من قراءة وكتابة وتنفيذ وإزالة جميع الأذونات السابقة التي لم ثذکر ووضع علامة الشرطة 
مكان الأذن للدلالة على إزالته. أما الاستخدام الثاني فهو مع أحد التحديدات التالية را أو و أو 0 حيث تقوم بإعطاء 
الصلاحيات المذكورة مع الأمر من قراءة وكتابة وتنفيذ وإزالة جميع الأذونات السابقة التي لم SS‏ وبالتالي وضع 


علامة الشرطة مكان الأذن للدلالة على إزالته ولكن فقط للفئة المحددة (المالك أو المجموعة أو الآخرين). 


اما الرمز الذي يمثل المستخدم المالك user owner‏ للملف فهو الحرف با والمستخدم مع الأمر chmod‏ 
الخاص بتعديل modify‏ الأذونات permissions‏ وأخيراً الحرف و والذي يمثل مجموعة المالكين group‏ 


.OWner 


لتعدیل أذونات الجميع استخدم الحرف ج بدلا من الحروف التالية 0 ۰ لا » 0. 


Yy 


T 
5 Me 
2230 اساسیات لینکس‎ ۲ 
بعض الأمثلة على تعدیل الأذونات (قراءةء كتابةء تنفیذ) وذلك للمستخدم (المالكء المجموعة الاخرین):‎ 
مع حرف المعنی‎ chmod الأمر‎ 
يعطي الجميع إذن التنفيذ.‎ chmod a+x file name 
يزيل من المجموعة إذن الكتابة.‎ chmod g-w file name 
اضافة للمجموعة والاخرین اذن القراءة.‎ | chmod go+r file name 
إعطاء للآخرين اذونات قراءة وكتابة وتنفيذ. وعدم تغيير الأذونات للفئتين‎ | chmod o-rwx file name 
chmod جدول أمثلة على تعديل الأذونات باستخدام الأمر‎ 
£ الخطوة‎ ٤ 
لاضافة إذن الكتابة‎ chmod استخدم الأمر‎ more public إذا كنت تريد أن تجعل دليل ما أكثر عمومية‎ 
:others للآخرين‎ 
ls -ld pub-dir/ 
chmod o+w pub-dir/ 
ls -ld pub-dir/ 
على الدليل‎ write permission لديهم إذن للكتابة‎ others أن الآخرين‎ oY! output یظهر في التنفيذ‎ 
الملفات داخل الدليل):‎ delete أو حذف‎ add على إضافة‎ ability (ونقصد بالكتابة القدرة‎ directory 
vw 
لله‎ 


اساسیات لینکس 


$ ls -ld pub-dir/ 
drwxrwxr-X 2 sysadmin sysadmin 4096 Apr 11 21:27 


$ chmod otw pub-dir/ 


$ ls -ld pub-dir/ 


drwxrwxrwx 2 sysadmin sysadmin 4096 Apr 11 21:27 


$ 


ts -ld pub-dir/ «chmod o--w pub-dir/ «ls -ld pub-dir/ »« 53! تنفیذ‎ 


٥ الخطوة‎ ٥ 


استخدم الأمر chmod‏ لازالة remove‏ أي إذن من المجموعة أو من الآخرين على الملف :priv-file‏ 


ls -l priv-dir/priv-file 


chmod g-rw,o-r priv-dir/priv-file 


ls -l priv-dir/priv-file 


يجب أن تظهر التنفيذ مشابه لما يلي: 


$ وا‎ -l priv-dir/priv-file 
-rw-rw-r-- 1 sysadmin sysadmin 0 Apr 11 21:26 priv-dir/priv-file 


$ chmod g-rw,o-r priv-dir/priv-file 


$ ls -l priv-dir/priv-file 


1 sysadmin sysadmin 0 Apr 11 21:26 priv-dir/priv-file 
$ 


ts -l priv-dir/priv «o-r priv-dir/priv-file«chmod g-rw «ls -l priv-dir/priv-file تنفیذ الأوامر‎ 


-file 


اساسیات لینکس 


٦ الخطوة‎ ٦ 
(وسيم إزالة الأذن الذي‎ pub-file أذونات القراءة والكتابة للملف‎ all users المستخدمين‎ ARS grant اعطي‎ 
لم يُذكر وهو التنفيذ من الجمیع):‎ 
ls -l pub-dir/pub-file 
chmod a=rw pub-dir/pub-file 
ls -l pub-dir/pub-file 


يجب أن تظهر التنفيذ مشابه لما يلي: 


$ ls -l pub-dir/pub-file 
-rw-rw-r-- 1 sysadmin sysadmin 0 Apr 11 21:27 pub-dir/pub-file 


$ chmod a-rw pub-dir/pub-file 


$ ls -l pub-dir/pub-file 


-rw-rw-rw- 1 sysadmin sysadmin 0 Apr 11 21:27 pub-dir/pub-file 
$ 


ls -l pub-dir/p «chmod a-rw pub-dir/pub-file «Is -l pub-dir/pub-file تنفيذ الأوامر الثلاثة‎ 


ub-file 


۷ الخطوة ۷ 


أنشأ الملف test.sh‏ في /tmp‏ والذي يحتوي على أمر التاریخ date"‏ ": 


echo "date" > 57 


ويكون التنفيذ مشابهه لما يلي: 


٢ 


اساسیات لینکس 


G echo "gene" > test- -sn 


$ 


echo "date" > test.sh تنفیذ الأمر‎ 


إذا کان ملف ما يحتوي على أوامر commands‏ فان تلك الأوامر يمكن تشغیلها run‏ إذا تم منح إذن التنفيذ 
execute permission‏ علیها المستخدم (مالك» de gaza‏ آخرين). وبالتالي یستطیع المستخدم التشغیل 
ویصبح الملف قابل للتنفيذ executable file‏ آما في حالة عدم وجود هذا الاذن؛ فان الملف لا يمكن أن تتم 


معاملته کبرنامج .program‏ 
۸ الخطوة ^ 


حاول تنفیذ الملف test.sh‏ (ویجب أن تبوء المحاولة بالفشل). ثم اعرض الأذونات permissions‏ على 


الملف لتری سبب الفشل: 


Jtest.sh 


ls - test.sh 


ويكون التنفيذ مشابهه لما يلي: 


5 5255 sin 


-bash: ./test.sh: Permission denied 


5 تا‎ = test- ۵ 


-rw-rw-r-- 1l sysadmin sysadmin 5 Apr 11 22:27 test.sh 


$ 


تنفیذ -Ltest.sh « /test.sh o» «Y!‏ کا 


۳۹۹ 


اساسیات لینکس 


۹ الخطوة ۹ 


يُسمح فقط للمستخدم المالك user owner‏ للملف jl)‏ المستخدم الجذر (root‏ بتغيير الأذونات على الملف. 


اعطي المستخدم المالك إذن التنفيذ execute permission‏ ثم نفذ الملف :test.sh‏ 


chmod u+x 517 
ls - test.sh 


Jtest.sh 


التنفیذ يُظهر إضافة إذن التنفیذ للمستخدم المالك user owner‏ للملف وأيضاً التاریخ والوقت الحالي لتنفیذ الأمر 


6 داخل الملف النصي script file‏ السابق :test.sh‏ 


5 chmod u*x test.sh 


5 وا‎ -L rest- eh 


-rwxrw-r-- 1l sysadmin sysadmin 5 Apr 11 22:27 
$ ./test.sh 


Mom Ape انا‎ 228535225 UIC ۵ 


$ 


Jtest.sh «ls -Ltest.sh «chmod u«x test.sh تنفيذ الأوامر‎ 


في الفقرة السابقة تعلمت AS‏ استخدام الأمر chmod‏ مع التدوين الرمزي «symbolic notation‏ حيث یتم 
استخدام )354 symbols‏ للتعبير عن الفئة وهي (لاء «(a ۰0 g‏ وللتعبير عن عملية المنح أو الإزالة تم 
استخدام الرموز (+ e‏ -۰ -)» وأخیراً وللتعییر عن الأذن تم استخدام الرموز (X «Ww e r)‏ ولکن؛ وبجانب إستخدام 


التدوين الرمزي» فان الأمر chmod‏ يمكن استخدامه مع قيمة رقمية (لیست رمزية) تمثل أيضاً أذونات المستخدم 


المالك والمجموعة والاخرین وتعرف باسم التدوین الثماني „octal notation‏ 


لاستخدام الأمر chmod‏ مع التدوین الثماني» يجب عليك أولاً فهم قيمة الثمانية من الأذونات: 


۳۹۷ 


الإذن القيمة 
قراءة ٤ Read (r)‏ 
كتابة Write (w)‏ 3 
تنفيذ Execute (x)‏ ۱ 


جدول القيمة الثمانية 


من تفاصیل الملف السابق 1651.51 نرى الأذونات کالتالي --]-۲۷۷۲۷۷ء حیث أن للمستخدم المالك» و 
۷ للمجموعة و ۲ للآخرين. وللتعبير عن هذه الأذونات بالتدوين ثماني notation‏ 00131؛ سيتم جمع القيمة 


العددية لكل إذن. 

ولنبدأ أولاً بأذونات المستخدم المالك user's permission‏ حيث أن الأذونات التي لديه rwx‏ تكون قيمتها 
A‏ على التوالي )£ للقراءة» ۲ للكتابة و ۱ للتنفیذ)ء نقوم الان بعملية جمع لتلك القیم كما يلي : + ۲ + ۰۷<۱ 
فتصبح قيمة الأذونات بالتدوين الثماني للمالك هي ۷۔ 

(Gus‏ لننتقل إلى أذونات المجموعة «group's permission‏ حيث أن للمجموعة الأذونات التالية rw‏ وتكون 
قیمتھا ٤١٤٤‏ على التوالي )£ للفراءةء Y‏ للكتابة)» نقوم الآن بعملية جمع لتلك القيم كما يلي ٤‏ + ۲ <1. إذن القيمة 


الثمانية لأذونات المجموعة هي 5. 


وأخيراًء أذونات ملكية الآخرين cothers' ownership permission‏ ببساطة الآخرين لديهم إذن القراءة ۲ 


وقيمته ٤ء‏ وبالتالي فإن القيمة الثمانية لأذونات الآخرين هي .٤‏ 


الخطوة الأخيرة هي وضع تلك النتائج معاً ( مجموع المالك» مجموع المجموعةء مجموع الآخرين)؛ فتصبح القيمة 


الثمانية octal value‏ للأذونات الملف هي VÉ‏ 


E الخطوة‎ ۱۵,۲۰ 


استخدم الأمر stat‏ لروية القيمة التمانية octal value‏ للأذونات permissions‏ الملف «test.sh‏ وبالتالي 
التحقق verify‏ من حسابات الخطوة السابقة: 


۳۹۸ 


اساسیات لینکس 


stat 05 


ويكون التنفيذ مشابهه لما يلي: 


5 erat test- ۵8 


File: ^test.sh' 


Size: 5 Blocks: 8 IO Block: 4096 regular file 


Device: fc00h/64512d Inode: 3540004 Links: 1 
Access:(0764/-rwxrw-r--) Uid: ( 1001/sysadmin) Gids ( 1001/sysadmin) 
Access: 2016-04-11 22:27:24.987740243 -0000 

Modify: 2016-04-11 22:27:24.987740243 0 

Change: 2016-04-11 22:35:08.335757863 0 


8272608 = 


تنفیذ الأمر 1051.51 stat‏ 


إذا كنت تريد تغيير هذه الأذونات permissions‏ باستخدام التدوین الثماني octal notation‏ وذلك لاعطاء 


المجموعة group‏ والاخرين others.‏ إذن التنفیذء فانك سوف تستخدم الأرقام الثلاثة التالية: 
۷ (قراءة» كتابة وتنفیذ) للمالك. 

ارامہ اة رف ed‏ 

٥‏ (قراءة وتنفيذ) للآخرين. 


إذن يصبح الوضع الجديد mode‏ 16۷۷ء أو القيمة الثمانية للأذونات الملف 1951.51 هي .٥٧٧‏ 


14 الخطية ۱۱ 


باستخدام التدوین الثماني octal notation‏ قم بتعديل modify‏ أذونات الملف 1651.51 ليكون جميع 


لمستخدمين قادرين على تنفیذ الملف: 


۳۹۹ 


س0 اساسیات لینکس 
chmod 775 test.sh‏ 
ls - test.sh‏ 
ويكون التنفيذ مشابهه لما يلي: 


5 chmod 775 test.sh 


© [s = rest- sm 


-rwxrwxr-x 1l sysadmin sysadmin 5 Apr 11 22:27 


$ 


ls -L test.sh «chmod 775 test.sh تنفيذ الأمر‎ 


هناك نوعان من الأوامر التي يمكن أن تؤثر affect.‏ على ملكية الملفات «files ownership‏ الأمر الأول هو 
07 ومن خلاله يمكن تغيير مالك الملف أو تغيير المالك والمجموعة اللذان يملكان الملف. ولكن لا يمكن 


تنفيذ ذلك الأمر إلا من قبل المستخدم الجذر root‏ 


الأمر الثاني والذي يؤثر على ملكية الملف هو الأمر chgrp‏ والذي يمكن استخدامه من قبل المستخدم الذي يملك 


الملف أو من قبل المستخدم الجذر ۲001. 
حيث يقوم الأمر 600۲0 بتغير المجموعة التي تملك الملف فقط ولیس مالك الملف. 


عندما يُستعمل الأمر chgrp‏ من قبل مستخدم غير رئيسي ۱186۲ 000-۲001 يمكنه فقط تغيير ملكية المجموعة 
إلى مجموعة يكون ذلك المستخدم عضواً بها. بينما يستطيع المستخدم الرئيسي root user‏ استخدام الأمر 


0 وذلك لتغيير ملكية المجموعة إلى أي مجموعة أخرى. 


۱۷ C EISE 


قم بتبديل المستخدم والدخول الى حساب المستخدم الرئيسي root user‏ لتكون قادراً على تنفيذ كل من الأمرين 


chgrp ; chown‏ لتغيير ملكية المجموعة إلى أي مجموعة: 


۷۰ 


اساسیات لینکس 


SU - 


(Enter the password: netlab123) 


ويكون التنفيذ مشابهه لما يلي: 


Password: 


تنفیذ الأمر - SU‏ 


١ ۷۴‏ 
انتقل الی الدلیل Jtmp‏ ثم قم بسرد تفاصیل الدلیل «pub-dir‏ ثم قم بسرد تفاصیل ما بداخله: 
cd /tmp‏ 
ls -ld pub-dir‏ 
ls -l pub-dir/pub-file‏ 
لاحظ يظهر في التنفيذ أن الدلیل pub-dir‏ والملف الذي بداخله pub-file‏ مملوكان للمستخدم sysadmin‏ 
ولمجموعة :sysadmin‏ 
cd /tmp‏ #~: 


4 ls -ld pub-dir/ 


drwxrwxrwx 2 sysadmin sysadmin 4096 Apr 11 22:48 


# ls -l pub-dir/pub-file 


-rw-rw-rw- 1 sysadmin sysadmin 0 Apr 11 22:48 pub-dir/pub-file 
# 


تنفیذ الأوامر -l pub-dir/pub-file «Is -ld pub-dir «cd /tmp‏ کا 


۳۷۱ 


سال 
کر اساسیات لینکس 


4 ۵,۲,۱ الخطوة ۱ 


استخدم الأمر chown‏ لتغيير المالك والمجموعة للدليل pub-dir‏ إلى المستخدم الرئيسي root USer‏ 


والمجموعة الرئيسية croot group‏ ثم قم بعرض تفاصیل الدلیل: 


chown ۲۵0۵:۲۵01 pub-dir 


ls -ld pub-dir 


و ينبغي أن يظهر في التنفيذ تغيير المالك والمجموعة: 


7 chown root:root pub-dir 


4 ls -ld pub-dir/ 


drwxrwxrwx 2 root root 4096 Apr 11 22:48 


# 


ts -ld pub-dir «chown root:root pub-dir تنفيذ الأمرين‎ 


٥١ الخطوة‎ ٥ 
:bin إلى المستخدم‎ pub-file لتغيير مالك الملف‎ chown استخدم الأمر‎ 


chown bin pub-dir/pub-file 


ls -l pub-dir/pub-file 


يظهر التنفيذ الآن أن المالك للملف هو المستخدم :bin‏ 


Yyy 


اساسیات لینکس 


# chown bin pub-dir/pub-file 


# ls -l pub-dir/pub-file 


-rw-rw-rw- 1 bin sysadmin 0 Apr 11 22:48 pub-dir/pub-file 
# 


تنفيذ الأمرين -L pub-dir/pub-file «chown bin pub-dir/pub-file‏ کا 


Pisas ۹ 


اعرض تفاصيل الدليل cpriv-dir‏ ثم قم بعرض تفاصيل محتوياته: 


-ld priv-dir‏ کا 


ls -l priv-dir/priv-file 


التنفيذ output‏ ينبغي أن يُظهر أن الدليل priv-dir‏ تعود ملكيته إلى المستخدم sysadmin user‏ وإلى 


:sysadmin مجموعة‎ 


# ls -ld priv-dir 
drwxrwx--- 2 sysadmin sysadmin 4096 Apr 11 22:48 priv-dir 


# ls -l priv-dir/priv-file 


1 sysadmin sysadmin 0 Apr 11 22:48 priv-dir/priv-file 


# 


ts -l priv-dir/priv-file «ls -ld priv-dir تنفیذ الأمرين‎ 


۱۷ الخطوة‎ ۱١١٧ 


يستخدم الخیار -R‏ مع الامر م0101 لتغيير المجموعة للدليل ولكل الملفات التي بداخله» غير المجموعة للدليل 
priv-dir‏ وما بداخله (الملف (priv-file‏ إلى مجموعة users‏ باستخدام الأمر chgrp‏ بشكل متكرر 


۷ باستخدام الخيار -R‏ ؛ ثم قم بعرض التفاصيل للدليل السابق: 


VY 


اساسیات لینکس 


-ld priv-dir‏ کا 


ls -l priv-dir/priv-file 


chgrp -R users priv-dir 


ls -ld priv-dir 


ls -l priv-dir/priv-file 


ويكون التنفيذ مشابهه لما يلي: 


# ls -ld priv-dir 
drwxrwx--- 2 sysadmin sysadmin 4096 Apr 11 8 
# وا‎ -l priv-dir/priv-file 
sysadmin sysadmin 0 Apr 11 22:48 priv-dir/priv-file 
7 chgrp -R users priv-dir 
# ls -ld priv-dir 


drwxrwx--- 2 sysadmin users 4096 Apr 11 22:48 


# وا‎ - priv-dir/priv-file 


sysadmin users 0 Apr 11 22:48 priv-dir/priv-file 


# 


ts -ld priv- «chgrp -R users priv-dir «ls -l priv-dir/priv-file «ls -ld priv-dir تنفیذ الأوامر‎ 
کا‎ -l priv-dir/priv-file «dir 

یظهر في النتيجة السابقة أنه عند تنفيذ تغییرات على دليل بشكل متكرر recursively‏ فان التغييرات تطبق 

على الدليل وکل محتوياته. بمعنى أن كل الملفات والأدلة الفرعية subdirectories‏ التي تحت الدليل priv-‏ 


dir‏ وکل محتوياتها من ملفات وأدلة فرعية سيطبق عليها هذا التغيير. 


VE 


٧0 | Ep A‏ . بپ 
M‏ ساسیات لینکس 2756 


المعمل السادس عشر - آذونات خاصة روابط 
Special Permissions, Links and File‏ 


Locations 


۳۷۵ 


۱۳ 


ا مه مت یا 


IL 


و اساسيات لينكس 2230 


عن الأذونات الخاصة special permissions‏ وأنواع مختلفة من ملفات الارتباط ink files‏ 


e‏ عرض ملفات ذات أذونات خاصة. 


. Soft واللينة‎ hard إنشاء الروابط الصلبة‎ e 
الاطلاع على الأذونات الخاصة‎ ۲ 


في هذه المهمة سوف تفهم ما هو الغرض من الأذونات الخاصة special permissions‏ غير القراءة والكتابة 


والتنفيذ. 
EA‏ 


:Jvar/tmp JA s /tmp اسرد تفاصیل الدليل‎ 


ls -ld ۵ 


ls -ld /var/tmp 


یظهر في التنفيذ output‏ أن الأذونات permissions‏ على الدليلين السابقين متماثلة كما هو واضح: 


اساسیات لینکس 


:~$ وا‎ -ld /tmp 


drwxrwxrwt 2 root root 4096 Mar 14 17:34 


:~$ وا‎ -ld /var/tmp 


drwxrwxrwt 2 root root 4096 Apr 19 2012 


D$ 


ls -ld /var/tmp «ls -ld /tmp تنفیذ الأمرين‎ 


الاذونات في الدليل /tmp‏ والدلیل /var/tmp‏ من قراءة وكتابة وتنفیذ معطاه لجميع المستخدمین. بجانب دلائل 
المستخدمين الرئيسية home directories‏ 'users؛‏ يوجد هذان الدلیلان المؤقتان temporary‏ 
5 في نظام الملفات Cus filesystem‏ يمكن للمستخدمين العادیین ordinary users‏ 


انشاء create‏ ملفات جديدة أو دلائل. 


وهذا يشكل مشكلة «problem‏ 138 کان لكافة المستخدمین all users‏ آذونات لانشاء ملفات جديدة» سیکون 
لديهم أيضا إمكانية حذف delete‏ الملفات الموجودة existing files‏ وذلك لأن إذن الكتابة على دليل ما یمنح 


المستخدمین القدرة على إضافة وحذف الملفات في ذلك الدلیل. 


لاحظ وجود حرف † في مكان خانة التنفيذ execute column‏ لأذونات الاخرین others permissions‏ 
في all‏ السابق (drwxrwxrwt)‏ حیث يشير إلى أن هذا الدلیل لديه مجموعة آذونات من نوع البت اللاصق 
„sticky bit‏ هذا الاذن الخاص يعني أنه على الرغم من أن الجمیع قادر على إضافة ملفات إلى دلیل ما؛ الا أن 


المستخدم الذي أنشأ الملف ذلك الملف هو الذي يمكنه حذفه. 


وتجدر الاشارة إلى أن المستخدم الرنيسي الجذر root user‏ لا يتأثر بهذا الاذن؛ Cus‏ بستطیع حذف جمیع 


الملفات في أي دلیل بغض النظر عن „ownership kish‏ 
Y, Y, Y‏ الخطوة Y‏ 


اعرض الأذونات permissions‏ على الملف Jetc/shadow‏ 


YY 


A‏ اساسیات لینکس 


ls -l /etc/shadow 


نری في التنفيذ التالي (rw-r----- 1 root shadow)‏ ونجد أن المالك هو المستخدم الجذر root user.‏ ولديه 
إذن قراءة ۲ وكتابة ۷۷ء كما يظهر في التنفیذ المجموعة وهي shadow‏ ولأعضائها إذن القراءة er‏ وأخیراً نجد 


الآخرين others‏ بدون اي أذونات على الملف: 


:~$ وا‎ -l ۷ 


-rw-r----- 1 root shadow 838 Mar 14 17:34 /etc/shadow 


وب : 


ls -L/etc/shadow «Y! تنفیذ‎ 


مثل الملفات الأخرى الموجودة في دليل «etc‏ الملف /etc/shadow‏ يحتوي على معلومات معينة لتكوين 
المضیف .host-specific configuration information‏ وتحدیداء يحتوي ملف /etc/shadow‏ على 
کلمات السر المشفرة encrypted passwords‏ لجمیع حسابات all accounts‏ المستخدمين المحليين 
local user‏ ومعلومات عن عمر كلمة السر password aging‏ (إلى متى تكون كلمة مرور صالحة). وبما 
أن هذه المعلومات حساسة جدا sensitive information‏ very؛‏ فان الوصول access‏ إليها محدد 
0 بالمستخدم الجذر «oot user‏ وبالأوامر التي ثنفذ بصلاحیاته «as root‏ وأيضاً أعضاء 


.shadow مجموعة‎ members 


يتم تحديث updates‏ کلمة المرور password‏ الخاصة بالمستخدمین عن طریق الأمر passwd‏ الذي 41 
إذن خاص يسمى .setuid‏ إذن setuid‏ يعطي الصلاحیة للتنفيذ كأنك المستخدم الذي يملك الملف shadow‏ 


(وهو المستخدم (root‏ وذلك للمستخدم الفعلي الذي أصدر الأمر. 


إذا كانت لديك خبرة في نظام التشغیل مایکروسوفت ویندوز Microsoft Windows‏ فيمكنك اعتبار الاذن 


"Run as administrator کأنه مماثل للامر " تشغیل کمسوول النظام‎ setuid 


YYA 


ٹچ کات 
۳ الخطوة ۳ 
اعرض آذونات permissions‏ للأمر /usr/bin/passwd‏ 
ls - ۵۵۵۷۵‏ 


وينبغي أن یظهر التنفیذ كما يلي: 


:~$ وا‎ -l /usr/bin/passwd 


ISE ع كرك‎ D 29 00r 42924 Sep 12 2012 


وه : 


تنفيذ الأمر -L/usr/bin/passwd‏ کا 


لاحظ وجود حرف S‏ في مکان خانة التنفیذ للمستخدم المالك ews‏ ویدل هذا الحرف على أن هذا الأمر يحتوي 
على مجموعة أذونات من نوع «etuid‏ وبالتالي سیتم تنفیذ الأمر passwd‏ من قبل المستخدم الفعلي المُشغل 


للأمر وكأنه المستخدم الذي يملكه (وهو المستخدم الجذر). 


ولهذا فان الأمر passwd‏ قادر على تحدیث update‏ الملف /etc/shadow‏ لأنه ينفذ باسم المستخدم ۲001. 
(تذکر أن المستخدم الجذر root user‏ يمكنه تحرير edit‏ أي ملف» بغض النظر عن الأذونات permissions‏ 


الموجودة عليه). 


f الخطوة‎ ۲۶ 


اعرض الأنونات permissions‏ للامر /usr/bin/wall‏ 


ls -l /usr/bin/wall 


۳۷۹ 


اساسیات لینکس 


یظهر في التنفیذ حرف و؛ وتحديداً في مکان Ada‏ التنفيذ لأذونات المجموعة ۲-5 كما يلي: 


:~$ ls -l /usr/bin/wall 


PE كدت‎ D seo wey 116 Jom LE 2014 


وب : 


تنفیذ الأمر -L/usr/bin/wall‏ کا 


حرف و الموجود في عامود التنفيذ للمجموعة يشير إلى أن هذا الأمر يحتوي على مجموعة آذونات من نوع 
0 لذلك فانه سینفذ من قبل أعضاء المجموعة المُشغلين للأمر وکأنهم من مجموعة المالکین (tty)‏ و هکذا 
فان الأمر wall‏ يكون قادراً able‏ على الكتابة write‏ إلى جمیع النوافذ الطرفية terminals (ttys)‏ حیث 


أنه پُنفذ کمجموعة tty‏ 


ملاحظة: الاذن 561010 مشابه جداً للإذن tsetuid‏ ولکن بدلا من تشغیل الأمر بصفة المستخدم مالك البرنامج» 


يُشغل الأمر بصفة المجموعة المالكة للبرنامج. 


حتی الان» شاهدنا ثلاثة آنواع من الأذونات الخاصة: sticky bit‏ على دلیل» setuid‏ على ملف قابل للتنفیذ 
executable file‏ والإذن 561010 على ملف Jt‏ للتنفيذ executable file‏ أيضاً. US‏ شاهدنا؛ فان 


جميع تلك الأذونات موجودة exist‏ على أي نظام نموذجي typical system‏ 


بجانب ما سبق فإنه as s‏ إذن خاص special permission‏ آخر يمكن استخدامه وهو إذن 561010 والذي 


يمكن تطبيقه applied‏ على دلیل „directory‏ 


فإذا cul‏ حرف و في مكان خانة التنفيذ لأذونات المجموعة المالكة للدليل؛ فهذا يشير إلى ان الدليل لديه إذن 
0. وبالتالي فان أي ملف أو دليل جديد يتم إنشاؤه في هذا الدليل سيكون Lilli‏ مملوكاً من قبل المجموعة 


التي تملك الدلیل» ولیس من قل أعضاء المجموعة الذين انشاوا الملف. 


۳۸۰ 


با 


230 اساسیات لینکس‎ ES 


و للروايظ الصایه و لاینڈ 


في هذه المهمة» سنقوم بانشاء واستخدام الروابط links‏ الصلبة واللينة .hard and soft‏ 


peba 34 


انتقل الى الدلیل الرئيسي :home directory‏ 


۲ ۳۳٣ ۴۰۶ 


قم بإنشاء ملف يسمى 5000106 يحتوي على النص التالي "data"‏ وذلك باستخدام آمر اعادة التوجیه: 


echo "data" » source 


Y الخطوة‎ ٣ 


اعرض تفاصیل وأیضاً معلومات inode‏ للملف :source‏ 


ls -li source 


نری في التنفیذ جزئیین مظللين باللون الأصفرء الأول في بداية التنفيذ ويشير إلى مؤشر الفهرسة inode‏ للملف 
وھو ٦‏ والذي يختلف من نظام إلى آخرء والثاني نراه بعد آذونات الملف وهو يشير الى ae.‏ الروابط link‏ 


:۱ لهذا الملف وهو كما نری الرقم‎ count 


س0 اساسیات لینکس 


:-$ وا‎ -li source 


E 5۷52070311 sysadmin 5 Apr 12 13:27 source‏ ]و 17و رت 


وم : 


ls -li source تنفیذ الأمر‎ 


يستخدم نظام التشغيل لينكس مؤشر الفهرسة inodes‏ لمواصلة تتبع keep track‏ المعلومات حول الملف. 


نظام مُدخلات الدليل directory entry‏ یربط associates‏ مؤشر الفهرسة inode‏ مع اسم الملف. 

أن إنشاء ارتباط صلب hard link‏ بين كائنين أو أكثر يجعل نظام مُدخلات الدليل directory entry‏ يقوم 
بربط الکائن الجديد الذي نريد عمل ارتباط صلب له مع مؤشر الفهرسة 1000 للکائن القديم (وبالتالي يُصبحان 
بنفس رقم (inode‏ وأيضاً سوف يزداد رقم عداد الارتباطات „link count number‏ 

تسمح الروابط الصلبة hard link‏ بوجود أسماء متعددة multiple names‏ للإشارة refer‏ إلى نفس الملف 


same file‏ حتى إذا تمت إزالة removed‏ أحد تلك الأسماء؛ فان الأسماء الأخرى يمكن استخدامها للإشارة 


إلى ذلك الملف. 


في الواقع» يمكن حتى استخدام تلك الأسماء الأخرى «Uy other names‏ ارتباطات إضافية additional‏ 
links‏ وتعتبر كل تلك الأسماء متكافئة equivalent‏ بما أنها جميعاً تشير إلى مؤشر فهرسي موجود existing‏ 


inode 


ملاحظة: لا يمكنك إنشاء ارتباطات صلبة hard links‏ بأي من الدلائل ولكن فقط بالملفات. أيضا الارتباط 


الصلب بملف يجب أن يكون موجوداً داخل نفس نظام الملفات (التقسیم (partition‏ بأنه مرتبط اليه. 


٤ الخطوة‎ 1۹,۳14 


استخدم الأمر ۸] لانشاء create.‏ ارتباط صلب hard link‏ ثم اعرض تفاصیل details‏ ومعلومات inode‏ 


للملف source‏ وملف الارتباط الصلب الجديد: 


YAY 


اساسیات لینکس 


ln source 6 ٣۶ 


ls -li source ۷ 


لاحظ أن الملف الجديد hardlink‏ والملف الأصلي source‏ بتشارکان نفس inode‏ 


:~$ ln source hardlink 


:~$ وا‎ -li source hardlink 


sysadmin sysadmin 5 Apr 12 13:27 hardlink‏ حك 12و 


121۵716 Sysadmin sysadmin 5 Apr 12 13:27 source 


وب : 


تنفیذ الأمرين source hardlink «In source hardlink‏ - کا 


٥ الخطوة‎ ٥ 


إستخدم الأمر ۸] لانشاء ارتباط صلب آخر مع الملف «source‏ ثم اعرض تفاصيل وأيضاً معلومات مؤشر 


الأرشفة inode‏ للملفات التي تم عمل ارتباط لها: 


ln hardlink 06 


-li hardlink hardtoo source‏ کا 


لجميع الملفات المرتبطة عند إضافة الارتباط الجدید: 


YAY 


اساسیات لینکس 


5 ln source 2000 


5 وا‎ -li hardlink hardtoo source 


-YW riw دح‎ sysadmin sysadmin 5 Apr 12 13:27 hardlink 


FEWR EWE E Sysadmin sysadmin 5 Apr 12 13:27 6 


a VV سم عم‎ Sysadmin sysadmin 5 Apr 12 13:27 source 


$ 


ls -li hardlink hardtoo source «ln hardlink hardtoo تنفیذ الأمرين‎ 


٦ الخطوة‎ Y, 


: hardlink و‎ source الارتباط الأخیر التي تم انشاوه» ثم قم بسرد تفاصيل الملفین‎ remove Jj 


rm hardtoo 


-li source hardlink‏ کا 


لاحظ أن alae.‏ الارتباطات link count‏ تناقص decreases‏ عند إزالة removed‏ أحد الملفات المرتبطة 


:hard linked file الصلبة‎ 


$ rm hardtoo 


$ وا‎ -li source hardlink 


۷ رح‎ 12 sysadmin sysadmin 5 Apr 12 13:27 hardlink 


Sysadmin sysadmin 5 Apr 12 13:27 source‏ س 3 رس ا 


$ 


ls -li source hardlink «rm hardtoo الأمرين‎ 3i 


V الخطوة‎ ۷ 


أزل ملف الارتباط الصلب chardlink‏ ثم قم بسرد تفاصیل الملف :source‏ 


۳۸ 


اساسیات لینکس 


rm hardlink 


ls -li source 


وينبغي ان يكون التنفیذ كالتالي: 


:~$ rm hardlink 


:~$ وا‎ -li source 


SEWE EWE E sysadmin sysadmin 5 Apr 12 13:27 source 


$ 


ls -li source «rm hardlink تنفیذ الأمرين‎ 


الآن ننتقل الى النوع الآخر من الارتباطات التي يمكن إنشاؤها وهو ما یعرف باسم الارتباط الرمزي symbolic‏ 
link‏ أو اللين link‏ 501. وفي هذا النوع من الروابط لا يزيد عداد الارتباطات link count‏ للملفات المرتبطة 


.linked files 


ملفات الارتباط الرمزية symbolic link files‏ لها مؤشر آرشفة inode‏ ونوع ملف file type‏ مستقل 
وخاص بھا. Yad‏ من ربط ومشاركة inode‏ فانها ترتبط مع اسم الملف (usi file name‏ عكس الارتباطات 
الصلبة thard links‏ يمكن للروابط اللينة soft links‏ أن ترتبط بالدلائل directories‏ ويمكنها أن تعبر 


5 الأجهزة والأقسام devices and partitions‏ لتصل إلى وجهتها. 


۸ الخطوة ۸ 


انشی ارتباط رمزي symbolic link‏ مع الملف «source‏ ثم قم بعرض التفاصیل لكلا الملفین المرتبطین: 


ln -s source softlink 


ls -li source softlink 


٨۸٥ 


اساسیات لینکس 


بين التنفيذ المظلل باللون الأصفر أن الملف softlink‏ والملف Ge source‏ 100065 مختلف. لاحظ انه يتم 
انشاء نوع ارتباط link type‏ للملف عند عمل ارتباط رمزي ul symbolic link‏ أذونات الارتباط link‏ 
5 فهي ليست ذات صلة sirrelevant‏ حیث أن أذونات الملف الهدف target file‏ هي التي 


تحدد امكانية الوصول 20606655: 


:~$ ln -s source softlink 


:-$ وا‎ -li source softlink 


5۱۷52 01111 sysadmin 6 Apr 12 13:56 -=> ح وت‎ 


EES ll ته‎ 07 977996000 5 Apr 12 13327 68 


:~$ 


تنفیذ الأمرين -li source softlink «In -s source softlink‏ کا 
٣۹‏ الخطوة q‏ 
انشئ ارتباط رمزي symbolic link‏ مع الدلیل ۰/0۲06 ثم قم بعرض تفاصیل الرابط: 
ln -s /proc crossdir‏ 
ls -l crossdir‏ 


نجاح هذه الأوامر دليل على أن الروابط soft links Xlll‏ يمكن أن تشير إلى الدلائل «directories‏ وأنها 
يمكن تعبر cross‏ من ملف نظام filesystem‏ إلى آخرء وهما المهمتان التي لا تستطيع الروابط الصلبة 


hard links‏ أن تقوم بها: 


:-$ ln =5 /proc 7 


:-$ وا‎ -l crossdir 


lrwxrwxrwx 1 sysadmin sysadmin 5 Apr 12 14:00 


وم : 


تنفيذ -l crossdir «In -s /proc crossdir‏ کا 


YAT 


لا 


YAN 


2030 
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A‏ اساسيات لينكس 


الملحق رقم (۱) 


ملخص لأوامر المعمل الرابع: 


المعنی 

یعرض اسم المستخدم الحالي للنظام. 

عرض اسم نواة نظام التشغیل. 

6 عرض اسم نواة نظام التشغیل» آما مع الخیار 0- مع 
فسيتم عرض اسم مضيف الشبكة. 

6 عرض اسم نواة نظام التشغيل» أما مع الخيار -- 
6 فهو يشبه -n‏ وذلك لعرض اسم مضيف الشبكة. 
عرض المسار للموقع الحالي. 

0 يقوم بالإخراج على الشاشة لجملة „Hello Student‏ 
echo‏ يقوم بالإخراج على الشاشة» وعلامة $ Qu‏ على أنه 
متغیر» أخيراً اسم المتغير ( PATH‏ ). 

۵ بحدد موقع ملف البرنامج في مسار المستخدم» وهنا 
مثال على استخدامه مع الأمر تاریخ .date‏ 

0 يقوم بالإخراج على الشاشةء و علامة النجمة * لعرض 
كافة أسماء الملفات والدلائل في الدليل الحالي. 

echo‏ يقوم بالإخراج على الشاشة؛ و D‏ يعني لكافة الملفات 
والدلائل في الدليل الحالي التي تبدأ بحرف «D‏ وتقوم علامة * 


بإكمال الاسم» حيث يمكن أن تكون قيمة النجمة * صفر أو أكثر. 


YAA 


Command -option string 


whoami 


uname 


uname -n 


name --nodename 


pwd 


echo Hello Student 


echo $PATH 


which date 


echo * 


echo D* 


E We 
اساسیات لینکس‎ AW 


0 يقوم بالاخراج على الشاشة» و P‏ يعني لكافة الملفات 
والدلائل في الدليل الحالي التي تبدأ بحرف «P.‏ وتقوم علامة * 
باکمال الاسم» حيث یمکن أن تكون قيمة النجمة * صفر أو أكثر. 
echo‏ يقوم بالإخراج على الشاشةء وعلامة * لإكمال الاسم» و 
5 تعني عرض كافة الملفات والدلائل في الدليل الحالي التي تنتهي 
بحرف cS‏ حيث يمكن أن تكون قيمة * صفر أو أكثر. 

0 يقوم بالإخراج على الشاشةء و D‏ يعني لكافة الملفات 
والدلائل في الدليل الحالي التي تبدأ بحرف (] ويتوسطها حرف 


n‏ وتنتهي بحرف «S‏ وتقوم علامة النجمة * بإكمال اسم الملف. 


الملفات والدلائل في الدليل الحالي التي تتألف من ستة أحرف» 


وبعبارة أخرى يكون طول الاسم بعدد الاستفهامات. 


لكافة الملفات والدلائل في الدليل الحالي التي تتألف من حرف (] 
في البداية ثم ثمانية خانات» وبعبارة أخرى يكون طول الاسم 


آسماء الملفات والدلائل في الدلیل الحالی المكونة من ستة أحرف 
أو أكثر (خمسة استفهامات و حرف S‏ و *) وتنتهي بحرف S‏ 
لاحظ أن النجمة * تعني صفر أو أكثر وبالتالي فان طول الكلمة 
لا یمکن أن يقل عن ستة آحرف» فهو ستة أو أكثر. 

0 يقوم بالإخراج على الشاشةه و الأقواس المربعة [ ] فهي 


لتحديد مجموعة؛ وبالتالي يتم عرض الملفات والدلائل في الدليل 


۳۸۹ 


echo ۳ 


echo *s 


echo D*n*s 


echo [DP]* 


س0 اساسیات لینکس 


الحالي التي تبدأ بأحد الحرفين D‏ و ٢ء‏ وتقوم علامة النجمة * 
بإكمال الاسم. 

0 يقوم بالإخراج على الشاشة» و الأقواس المربعة [ ] فهي 
لتحدید مجموعة؛ أما علامة التعجب! فهي للنفي؛ وبالتالي سيتم 
عرض الملفات والدلائل في الدليل الحالي التي لا ab das‏ 
الحرفين D‏ و P‏ حیث ستظهر جميع الملفات والدلائل ما عدا 
التي تبدأ بالحرفين السابقینء وتقوم علامة النجمة * بإكمال الاسم. 
0 يقوم بالإخراج على الشاشةء و الاقواس المربعة [ [ فهي 
لتحدید مجموعة؛ أما علامة الشرطة - فهي لتحدید مدی معین؛ 
وبالتالي سیتم عرض الملفات والدلائل في الدليل الحالي بدایةً من 
الحرف D‏ ثم ع ثم ..... الا أن نصل للحرف «P.‏ وتقوم علامة 
النجمة * باکمال الاسم. 

0 يقوم بالاخراج على الشاشة» و الاقواس المربعة [ ] فهي 
لتحدید مجموعة؛ وعلامة الشرطة - فهي لتحدید مدی معین؛ آما 
علامة التعجب! فهي للنفي؛ وبالتالي سیتم اظهار جمیع الملفات 
والدلائل في الدلیل الحالي التي لا تکون احرفها واقعة بین المدی 
D‏ و2ء وأخیراً تقوم علامة النجمة * باکمال الاسم. 

0 يقوم بالاخراج على الشاشة للجملة «Today is‏ اما 
علامة الاقتباس الخلفية فتدل على ان ما بداخلها هو امر ولیس 
نص عاديء وبالتالي عند التنفیذ يتم اظهار الجملة ثم التاریخ. 
0 يقوم بالاخراج على الشاشة للجملة «Today is‏ اما 
علامة الدولار $ فتدل على ان ما يليها بین القوسین هو آمر 


ولیس نص عاديء وبالتالي سیتم اظهار الجملة ثم التاریخ. 


۳۹۰ 


echo [!DP]* 


echo [D-P]* 


echo [!D-P]* 


echo Today is 86 


echo Today is $(date) 


س0 اساسیات لینکس 


This is the يقوم بالإخراج على الشاشة للجملة‎ echo 
اأما علامة الاقتباس المفردة فتقوم بمنع تنفيذ‎ 0 
الأمرء وبالتالي یتم اخراج الجملة كما هي» فیظهر عند تنفیذ الأمر‎ 
. This is the command '" 0816 ۰ نفس الجملة وهي:‎ 

This is the يقوم بالإخراج على الشاشة للجملة‎ echo 
اما الخط المائل مع علامات الاقتباس فیقومان‎ 0 
بمنع تنفیذ الأمرء وبالتالي یتم اخراج الجملة كما هي فیظهر عند‎ 
. This is the command ۱016۱ التنفیذ نفس الجملة:‎ 

This is the يقوم بالإخراج على الشاشة للجملة‎ echo 
علامة الاقتباس المزدوجة فليس لها تأثير‎ ul 0 
علی علامة الاقتباس الخلفية. وبالتالي عند التنفیذ یتم اظهار‎ 
الجملة ثم التاریخ.‎ 

0 قوم بالاخراج على الشاشة. LÍ‏ علامة الاقتباس 
الم زدوجة فلها تأثیر على رموز glob‏ حیث انها تعطل المعنی 
خاص بهم» وبالتالي یظهر عند التنفیذ التالي: D*‏ . 

echo‏ يقوم بالاخراج على الشاشة للكلمة Ul «Hello‏ علامة 
الفاصلة المنقوطة فتقوم بالفصل بين الأوامرء حيث سیتم تنفيذ 
آمر الاخراج الثاني لكلمة Linux‏ في سطر جدید» وبالمثل لأمر 
الاخراج الأخير حیث سیتم عرض كلمة Student‏ في سطر 
ثالثء وبالتالي تنفیذ کل أمر في سطر منفصل. 

امر false‏ بُعطي نتيجة خطأء ثم تأتي الفاصلة المنقوطة للفصل 
بين الأوامرء أما echo‏ فیقوم بالاخراج على الشاشة للكلمة 
«Not‏ ونفس Ju‏ في الأمر echo‏ الأخیر فیقوم بالاخراج 


على الشاشة للكلمة Conditional‏ في سطر جدید. 


echo This is the command 


"date" 


echo This is the command 


VdateV 


echo This is the command 


"gate" 


echo "D*" 


echo Hello; echo Linux; 


echo Student 


false; echo Not; echo 


Conditional 


GD‏ اساسیات لینکس 


0 يقوم بالاخراج على الشاشة للكلمة Ul Start‏ علامة 
الشرط واو .88 فتحتاج ان تکون الجملتان صحيحة لكي يتم 
تنفیذها. وبما آنها صحيحة فسیتم إخراج الكلمة الثانية «Going‏ 
وأخيراً سیتم (خراج الكلمة الثالثة «Gone‏ ونتيجة المنال هي 
اخراج الکلمات Start‏ و Going‏ و Gone‏ في سطور ستقلة. 
0 بقوم بالاخراج على الشاشة للکلمة Success‏ ثم 
علامة واو الشرطية .88 ثم امر false‏ والذي يُعطي نتيجة 
خطأء وبالتالي سیتم اخراج کلمة Success‏ فقط. 

6 يُعطي نتيجة خطأء ثم علامة جملة أو || والتي تحتاج أن 
يكون احد الجملتین صحیحاً لكي تتحقق» وبالتالي سیتم اخراج 
Fail Or‏ عن طريق الامر «X echo‏ صحیح. 

6 تعطي نتيجة صحیحة وتستخدم لعدم عمل أي شيء في 
الجملة ؛ فقط التوقف» وبالتالي فانها ثسبب عدم التنفيذ للجملة. 
لاظهار الوقت والتاریخ. 

يزيل الاوامر من الشاشة الطرفية لکنها تبقی في السجل. 
لعرض سجل بالاوامر المدخلة مع الترقیم. 

۷ ملعرض سجل بالاوامر المدخلة مع الترقیم والرقم 5 
يعني عرض آخر حمسة آوامر قمت بکتابتها. 

! لتنفیذ آمر مرة آخری بمعلومية رقم ذلك الامر» ورقم 94 هو 
رقم الأمر المراد تنفیذه» ویتم معرفة أرقام الأوامر عن طریق 


.history الأمر‎ 


۳۹۲ 


echo Start 88 echo Going 


&& echo Gone 


echo Success && false 


&& echo Bye 


false || echo Fail Or 


true || echo Nothing to see 
here 

date 

clear 

history 


history 5 


194 


A‏ اساسیات لینکس 


الملحق رقم (Y)‏ 
ملخص لأوامر المعمل الخامس: 


m 

لإظهار الوقت والتاريخ. 

0 لمعرفة المزيد عن آمر ما عن طريق صفحات دليل 
المستخدم. وفي المثال نريد عرض المزيد عن الأمر 0816. 
للخروج من صفحات دليل المستخدم. 

علامة | هي للبحت (Ala‏ صفحة دلیل المستخدم» عن الكلمة 116 
0 للبحث في صفحات دلیل المستخدم» و )- يعني البحث 
بالكلمة الرئيسية password‏ وبالتالي اظهار النتانج التي تحتوي 
على الكلمة السابقة في أي مکان بالمستند (العنوان و المحتوی) 
وبدون الدخول إلى الصفحات» فقط في سطر الاوامر. 

ملاحظة: الأمران man -k‏ و apropos‏ يؤديان نفس الوظيفة. 
5 امر آخر للبحث في صفحات دلیل المستخدم. بالكلمة 
الرئيسية password‏ وبالتالي اظهار النتائج التي تحتوي على 
الكلمة السابقة في أي مکان بالمستند (العنوان والمحتوی) وبدون 


الدخول إلى الصفحات» فقط في سطر الأوامر. 


ملاحظة: الأمران apropos‏ و man -k‏ يؤديان نفس الوظيفة. 


man‏ يقوم بالبحث في صفحات دلیل المستخدم» و]- تعني البحث 
بالاسم passwd‏ بدون الدخول إلى الصفحات. وبالتالي اظهار 
النتانج التي تحتوي على الاسم کامل في عنوان المستند فقط. بدون 


استعراض للمحتویات» فقط في سطر الأوامر. 


۳۹۳ 


Command -option string 
date 


man date 


q 
[file 


man -k password 


apropos password 


man - passwd 


A‏ اساسیات لینکس 


ملاحظة: الأمران man -f‏ و whatis‏ یقومان بنفس العمل. 


0 للبحث في صفحات دليل المستخدم» ورقم 5 يعني البحث 
داخل القسم رقم 5 ء وأخيرا الكلمة التي نريد البحث عنها 
0 واستعراض تلك المحتويات. 
5 أمر آخر للبحث في صفحات دليل المستخدم بدون 
الدخول إلى الصفحات» وبالتالي يتم اظهار النتائج التي تحتوي على 
الاسم في عنوان المستند فقط وهو passwd‏ بدون استعراض 
للمحتويات» فقط في سطر الأوامر. 
ملاحظة: الأمران ۷13118 و man -f‏ يقومان بنفس العمل. 
0 صفحات المعلومات هي لإعطاء معلومات تفصيلية عن 
بعض الأوامر» مثل الأمر .date‏ 

.0816 عرض كيفية استخدام الأوامر الاساسية للامر»‎ -help 
وا عرض قائمة بالملفات والدلائل» و ]- لاعطاء التفاصيلء للكائن‎ 
لاحظ أن‎ «/usr/share/doc والموجود بالمسار المطلق‎ 6 
الاستعراض من المكان الحالي ولا نحتاج الى الانتقال إلى ذلك‎ 
المسار.‎ 

6 لتحدید موقع ملف باسم .crontab‏ 

6 لتحدید موقع ملف» و - لإظهار الملفات التي بنفس 
الاسم ولیس الامتدادء وأخيراً اسم الملف „crontab‏ 


5 لمعرفة موقع أمر ما. وهو هنا الأمر passwd‏ 


man 5 passwd 


whatis passwd 


info date 


date --help 


ls /usr/share/doc 


locate crontab 


locate -b ^crontab" 


whereis passwd 


A‏ اساسیات لینکس 


الملحق رقم (Y)‏ 
ملخص لأوامر المعمل السادس: 


المعنی 

عرض المسار للموقع الحالي. 

0 يقوم بالإخراج على الشاشة» وعلامة 8 تدل على أنه متغیر» 
أخيراً اسم المتغير (HOME)‏ 

0 أمر انتقال الى مسار ماء وهو الدليل الجذر / ۔ 

0 أمر انتقال الى مسار ماء وافتراضياً إذا لم يُكتب شيء بعد 
الأمر؛ يتم الانتقال إلى الدليل الرئيسي للمستخدم الحالي € ورمزه ~. 
cd‏ أمر انتقال الى مسار ماء و علامة تيلدا - هي الدليل الرئيسي» 
وإذا لم يُكتب اسم المستخدم» فسيتم الانتقال الى الدليل الرئيسي 
للمستخدم الحالي. 

cd‏ أمر انتقال الى مسار ماء و علامة تيلدا - هي الدليل الرئيسي» 
وأخيراً اسم المستخدم .Sysadmin‏ 

cd‏ أمر انتقال الى مسار ماء و home‏ هو الدليل الرئیسي؛ وذلك 
للمستخدم sysadmin‏ وهو نفس الأمر .cd ~ sysadmin‏ 
cd‏ أمر انتقال الى مسار ماء وهو الدليل home‏ . 

0 يقوم بالإخراج على الشاشةء وذلك للمسارات التالية: ~ 
sysadmin ~root ~mail ۱‏ ء واحداً تلو الاخر. 
cd‏ آمر انتقال الى مسار ماء و علامة تيلدا ~ هي الدليل الرئیسي» ثم 


اسم المستخدم root‏ (سيتم رفض الوصول). 


۳۹۵ 


Command -option string 
pwd 


echo $HOME 


cd / 


cd 


cd ~ 


cd 7 


cd /home/sysadmin 


cd /home 
echo - -sysadmin -root 
mail ۷ہ‎ 


cd -root 


س0 اساسیات لینکس 


cd‏ آمر انتقال الى مسار ماء و home‏ هو الدلیل الرئيسي وذلك 
للمستخدم ]۲00. 

bin أمر انتقال الى مسار ماء وهو الكائن (ملف أو دلیل)‎ cd 
بالمسار المطلق.‎ usr الموجود داخل الدلیل‎ 

المسار المطلق: المسار الكامل لموقع الكائن من البداية الى النهاية. 
المسار النسبي: مسار کائن داخلي» ولا يُكتب في بدايته الرمز / . 
0 أمر انتقال الى مسار ماء و .. تعني العودة خطوة واحدة للخلف. 
0 أمر انتقال الى مسار ماء و ../.. تعني العودة خطوتين للخلف. 
0 أمر انتقال الى مسار ماء و.. تعني العودة خطوة للخلف» و ۷۵۲/ 
تعني الانتقال إلى الدليل Var‏ . 

وا عرض قائمة بالمحتويات الموجودة (ملفات ودلائل وملفات 
مضغوطة و...)» وإذا لم يتم تحديد أي موقع بعد الأمر فسيتم عرض 
المحتويات الموجودة في المسار الحالي. 

وا عرض قائمة بالملفات والدلائل» و -a‏ لإظهار الملفات أو الدلائل 
المخفية» وحيث أنه لم يتم تحديد أي موقع فسيتم عرض المحتويات 
الموجودة بالمسار الحالي. 

ها عرض قائمة بالملفات والدلائل» و |- لإعطاء التفاصيل» للكائن 
(ملف أو دلیل) chosts‏ لاحظ أن الاستعراض من المكان الحالي ولا 
نحتاج الى الانتقال إلى ذلك الكائن. 

وا عرض قائمة بالملفات والدلائل» و -l‏ لاعطاء تفاصيل كاملة» و 
h‏ لعرضها بلغة مقروءة للإنسان. وحيث أنه لم يتم تحديد أي موقع 


بعد الأمر فسيتم عرض المحتويات الموجودة في المسار الحالي. 


۳۹۹ 


cd 0 


cd /usr/bin 


cd.. 


cd ../.. 


cd ../var 


ls 


ls -a 


ls - /etc/hosts 


ls -lh 


AW‏ اساسیات لینکس 


ls‏ عرض قائمة الملفات والدلائل» و -R‏ لعرض Laj‏ ما يتفرع من 
الکائن» وأخیراً اسم الكائن 06۷ » وذلك بدون الانتقال إليه. 

ها عرض قائمة بالملفات أو الدلائل و - تمنع عرض الدلائل 
الفرعیةء وذلك للملفات التي تبدأ بحرف «S‏ والنجمة * لاکمال الاسم. 
ها عرض قائمة بالملفات أو الدلائل» و - تمنع عرض الدلائل 
الفرعية» للملفات التي تتكون من أربع خانات من «cà MI‏ لاحظ أن 
العمل من المكان الحالي. 

ها عرض قائمة بالملفات أو الدلائل» و - تمنع عرض الدلائل 
الفرعية» للملفات التي تبدأ بأحد الأحرف [2000]»لاحظ أن العمل 
من المكان الحالي. 

«(/etc/hosts) من المسار المطلق‎ hosts أمر نسخ. للملف‎ cp 
(مسار نسبي).‎ hosts إلى الموقع الحالي» وذلك باسم‎ 

hosts للملف‎ gll أمر نسخ» ۷- لعرض الحدث» ويكون‎ cp 
إلى‎ hosts باسم‎ «(/etc/hosts) الواضح في المسار المطلق‎ 
الموقع الحالي (مسار نسبي)ء لاحظ أن العمل تم من المكان الحالي.‎ 
من المسار‎ hosts أمر نسخ؛ و ۷- لعرض الحدث. للملف‎ cp 
إلى الموقع الحالي الذي أعمل منه (استخدم‎ (/etc/hosts) المطلق‎ 
لاحظ أن‎ ch لمعرفة الموقع الحالي) والنسخة تکون باسم‎ pwd 
العمل تم من المکان الحالي.‎ 

hosts آمر نسخ» ۷- لعرض الحدث» ویکون النسخ للملف‎ cp 
وسیتم نسخه إلى‎ f باسم‎ (/etc/hosts) الواضح في المسار المطلق‎ 
الموقع الجدید والذي یتضمن اسم الملف 606/۲/. لاحظ أن العمل تم‎ 
من المکان الحالي.‎ 


حذف الملف hosts‏ بالمسار النسبي. لأننا لم نستخدم رمز / 


۳۹۷ 


ls -R ۷ 


ls -d ۴ 


ls -d /etc/???? 


ls -d /etc/[abca]* 


cp /etc/hosts hosts 


cp -v /etc/hosts hosts 


cp -v /etc/hosts h 


cp -v /etc/hosts /etc/f 


rm hosts 


A‏ اساسیات لینکس 


0 أمر نسخ» و -V‏ لعرض الحدث. للملف hosts‏ من المسار 
المطلق ('etc/hosts)‏ والنقطة تعني النسخ إلى الموقع الحالي 
الملف بنفس اسم الملف الأصلي. 

0 آمر نسخ و م- تعني النسخ مع الاحتفاظ بالتفاصیل الاصلية 
للملفء ثم اسم الملف المراد نسخه وهو hosts‏ (بالمسار النسبي)» 
وأخيراً تحديد موقع النسخة الجديدة بالمسار المطلق 
(/home/sysadmin)‏ وحیث انه لم يتم تحديد اسم جديد فسيتم 
النسخ بنفس الاسم الأصلي. 

rm‏ أمر حذف» للملفين 0918ا و newname‏ بالمسار النسبي. 
7 لانشاء «Ji‏ باسم 1/۷66 بالموقع الحالي (مسار نسبي). 
cp‏ آمر نسخ» -R‏ يعني نسخ جميع الدلائل الفرعية ایضاء وذلك 
للدلیل udev‏ بالمسار المطلق /etc/udev‏ وتسمیته باسم MyetcC‏ 
(مسار نسبي)ء وبما ان الدلیل ۸/۷۵66 قد سبق انشاءه فسیقوم النظام 
بتحدیث الدلیل ونسخ البیانات اليه النسخة ستکون في المکان الحالي. 
ها عرض قائمة بالملفات أو الدلائل و |- بالتفاصیل» R‏ تعني 
عرض الدلائل الفرعية أيضا للدلیل 1/۷8٥‏ (مسار نسبي). 

.(rm bä لحذف الدلائل (بینما لحذف الملفات‎ -r آمر حذف.‎ rm 
لحذف الدلائل الفارغة فقط ثم اسم الدلیل.‎ 7 

touch i‏ له وظیفتین الاولی تحدیث الملف الموجود بهذا الاسم 
وهو في المتال ۰0۲6۳۱0۷6 اما اذا كان الملف غير موجود فسیقوم 
الأمر بانشائه بالاسم السابق في المکان الحالي (مسار نسبي). 

۷ أمر قص ولصق. للملف 0۲6۳۱0۷6 ولصقه باسم 


.postmove 


۳۹۸ 


cp -v /etc/hosts ۰ 


cp -p hosts 


/home/sysadmin 


rm hosts newname 
mkdir Myetc 


cp -R /etc/udev Myetc 


Myetc‏ - کا 


rm -r Myetc 


rmdir 


touch premove 


mv premove postmove 


س0 اساسیات لینکس 
الملحق رقم )٤(‏ 


المعنی Command -option string‏ 
۲ امر ارشفة -c‏ انشاء الملف. ۷ لإظهار العملية» f‏ لتحديد tar -cvf mybackups/udev.tar‏ 
الاسم» والاسم هو udev.tar‏ ويُوضع في الدليل /etc/udev‏ 
6 (مسار نسبي) » وأخيراً اسم الدلیل الذي نريد 
ارشفته وهو udev‏ والواضح في المسار المطلق Jetc/udev‏ 
لاحظ أن الاسم يجب أن يحتوي على نوع الامتداد وهو lar‏ 

tar -tvf mybackups/udev.tar ۷ امر ارشفة » ]- عرض محتويات الملف المژرشف»‎ ٣ 
لتحديد الاسم» وهنا اسم الملف 06۷.18۳ لا‎ f لإظهار العملیة‎ 


الموجود في الدليل mybackups‏ (مسار نسبي). 


۲ امر -z dij‏ لضغط الملف» م لانشاء الملف. ۷ لإظهار tar -zcvf‏ 
العملية» f‏ لتحدید الاسم» ويكون اسم الملف udev.tar.gz‏ في mybackups/udev.tar.gz‏ 
الدليل mybackups‏ (مسار نسبي)ء وأخيراً اسم الدليل الذي letc/udev‏ 


نريد ارشفته وهو 06۷ والواضح في المسار المطلق 
۷ لاحظ أن الاسم يجب أن يحتوي على نوع الامتداد 
وبما أن الملف مؤرشف ومضغوط فیجب أن يكون tar.gz‏ 

۲ امر ارشفة -x c‏ استخراج محتويات ملف مضغوط V‏ 75 لالا tar -xvf‏ 
لاظهار العملية» f‏ لتحديد الاسم. وهو udev.tar.gz‏ (مسار 
نسبي). 

۲ امر ارشفة -r‏ اضافة ملف جدید إلى ملف المژرشف» tar -rvf udev.tar 15 V‏ 


لإظهار العملية» | لتحديد الاسم. واسم الملف المؤرشف السابق 


۳۹۹ 


اساسیات لینکس 


فهو udev.tar‏ (مسار نسبي)ء آما الملف الجديد الذي نريد 
اضافته فهو hosts‏ والموجود في الدليل /etc‏ كما في المسار 
المطلق letc/hosts‏ . 

0 امر ضغط للملف ۷۷0۲05 (مسار نسبي). 

لاحظ انه لا يجب عليك AUS‏ نوع الامتداد هنا كما مع الامر tar‏ 
0 امر لفك الضغط « عن الملف Words.gz‏ 

2 امر آخر للضغط وذلك الملف words‏ (مسار نسبي). 
2 امر لفك الضغط عن الملف words.bz2‏ 

zip‏ امر آخر للضغط ثم اسم الملف المضغوط الجدید 
0 واخيراً الملف الذي تريد ضغطه words‏ (مسار 
نسبي) . 

210 امر آخر للضغط ثم اسم الملف المضغوط الجدید eW‏ 
واخيراً الملف الذي ترید ضغطه words‏ (مسار نسبي). 

لاحظ أنه لا يتوجب عليك وضع الامتداد هنا وهو zip‏ لأن الأمر 
یقوم بذلك ولکن یتم وضعه عادة من المستخدم للتفریق. 

zip‏ امر ضغط -r‏ يستخدم لضغط الملفات jill‏ عية, ثم اسم 
الملف الجدید udev.zip‏ (مسار نسبي)» وأخيراً الملف الذي 
نريد ضغطه وهو udev‏ والواضح بالمسار المطلق /etc/udev‏ 
0 آمر لفك الضغط الخیار [- لعرض محتویات الملف 
المضغوط udev.zip‏ (مسار نسبي). 

0 لفك الضغط عن الملف المضغوط udev.zip‏ (مسار 


نسبي). 


gzip words 


gunzip words.gz 


bzip2 words 


bunzip2 words.bz2 


zip words.zip words 


zip w words 


zip -r udev.zip /etc/udev 


unzip - udev.zip 


unzip udev.zip 


س0 اساسیات لینکس 
الملحق رقم )2( 
ملخص لأوامر المعمل الثامن: 


المعنی 

0 يقوم بالإخراج على الشاشة Hello World" ilat‏ 
اما علامة التوجیه < فتعني اعادة توجیه الجملة الى الملف 
6 

.mymessage cl يعرض المحتویات.‎ 1 

echo‏ يقوم بإخراج الجملة "Hello World"‏ على الشاشة:؛ اما 
علامة التوجيه << فتعني إعادة توجيه الجملة الى الملف 
٥‏ دون مسح ما يوجد سابقاً بداخل الملف. 

hosts بمعيار الاسم عن‎ /etc أمر بحثء في الموقع‎ find 
مع‎ hosts أمر بحث. في الموقع ۵10/ بمعيار الاسم عن‎ find 
. 6۲۲. إلى الملف‎ (Y توجيه رسائل الخطأ (القناة رقم‎ 

6 أمر بحث. في الموقع etc.‏ بمعيار الاسم عن hosts‏ مع 
توجيه الإخراج القياسي (قناة رقم )١‏ الى 510.001 وتوجيه 
رسائل الخطأ (القناة رقم (Y‏ إلى الملف 510.67۲ . 

6 مر بحثء في الموقع etc.‏ بمعيار الاسم عن hosts‏ مع 
توجيه الإخراج القياسي (قناة رقم ١)ء‏ وأيضاً أعد توجيه رسائل 
الخطأ (القناة رقم ۲) مع الإخراج القياسي (قناة رقم )١‏ والذي 
سيذهب إلى الملف find.out‏ . 

وبالتالي فإن الإخراج القياسي ورسائل الخطأ ستتم إعادة توجيههم 


الى نفس المكان وهو الملف find.out‏ 


Command -option string 
echo "Hello World" < 


mymessage 


cat mymessage 
echo "Hello World" << 


mymessage 


find /etc -name hosts 
find /etc -name hosts 2< 
err.txt 

find /etc -name hosts > 


Std.out 2» std.err 


find /etc -name hosts 


»find.out 2-17 


س0 اساسیات لینکس 


tr‏ تحویل النص من حروف صغيرة 2-2 إلى كبيرة (A-Z‏ لاحظ 
أن المستخدم هو الذي يقوم بكتابة النص المراد تحویله. وللخروج 
بعد کثابة النص اضغط على Girl + d‏ 

8-2 إلى صغيرة‎ A-Z تحويل النص من حروف کبيرة‎ tr 
< > myfile إلى الملف‎ (stdout) وتوجیه الاخراج القياسي‎ 
. Ctrl + d وللخروج بعد كتابة النص اضغط على‎ 

A-Z تحويل النص من حروف صغيرة 2-2 إلى كبيرة‎ tr 
وعمل‎ myfile وعلامة > تعني اخذ البیانات الموجودة في الملف‎ 
التحویل علیها. إذن النص لا يتم إدخاله من قبل المستخدم.‎ 

وا عرض قائمة بالملفات والدلائل» |- بالتفاصيلء للدليل Jete‏ 
ثم علامة | لإعادة توجيه الناتج الى الامر more‏ (أمر more‏ 
يعرض النتائج على شكل صفحات). 

cut‏ آمر استخراج من قاعدة بیاناتء -d‏ للتحديد » و 11 للحقل 
رقم (Y‏ وذلك للملف passwd‏ والذي يحتوي على أسماء 
المستخدمين والموجود بالدلیل /etc/passwd‏ (مسار مطلق). 
cut‏ أمر استخراج من قاعدة بیاناتء -d‏ للتحديد » و 11 للحقل 
رقم (Y‏ وذلك للملف passwd‏ والذي يحتوي على أسماء 
المستخدمين والموجود بالدلیل /etc/passwd‏ (مسار مطلق). 
ثم الرمز | لإعادة توجيه النتائج الى الامر sort‏ والذي يقوم 
بفرز تلك النتائج من الأقل الى الأعلى. 

diali 11 للتحديد » و‎ -d أمر استخراج من قاعدة بیاناتء‎ cut 
والذي يحتوي على أسماء‎ passwd وذلك للملف‎ (Y رقم‎ 
(مسار مطلق).‎ /etc/passwd المستخدمين والموجود بالدلیل‎ 


ثم الرمز | لإعادة توجيه النتائج الى الامر sort‏ والذي يقوم 


ir a-z A-Z 


tr A-Z a-z > myfile 


tr a-z A-Z < myfile 


ls -l /etc | more 


cut -d: -f1 /etc/passwd 


cut -d: -f1 /etc/passwd | sort 


cut -d: -f1 /etc/passwd | sort 


| more 


اساسیات لینکس 


بفرز تلك النتائج. ثم اعد توجیه الناتج الى الامر more‏ لعرض 
النتائج على شكل صفحات وذلك باستخدام رمز الانبوب | . 
find‏ أمر بحث. في الموقع ‏ بمعيار الاسم عن ."bash*"‏ 
6 أمر بحثء في الموقع ~/Music‏ بمعيار الوقت -mmin‏ 
عن الملفات التي تم التعديل عليها خلال الدقائق 5- الماضية. 
find‏ أمر بحث. في الموقع /USr‏ بمعيار الحجم -size‏ عن 
الملفات التي حجمها أكبر من ٢‏ ميغا. 

- بمعيار النوع‎ /usr/share/bug أمر بحت. في الموقع‎ find 
عن الكائنات التي من نوع دليل.‎ type d 


6 أمر بحثء في الموقع /usr/share/bug‏ بمعيار النوع - 


type d‏ عن الكائنات التي من نوع دلیل» و وا لعرض قائمة بها. 


cat‏ آمر عرض المحتویات للملف passwd‏ كما هو موضح 
بالمسار المطلق letc/passwd‏ . 

passwd صفحات. للملف‎ (SS لعرض الملف على‎ more 
. Jetc/passwd كما هو موضح بالمسار المطلق‎ 

للبحث عن المساعدة داخل صفحات الامر .more‏ 

للانتقال للصفحة التالية داخل صفحات الامر .more‏ 

5 أمر أحدث لعرض الملف على شكل صفحات. للملف 
0 كما هو موضح بالمسار المطلق letc/passwd‏ . 
للبحث dah‏ صفحات الامر less‏ عن lbin‏ . 

لعرض اول نتيجة للبحث (bin)‏ وبالتالي عند الضغط على ۲ 
سينتقل التحديد الى النتيجة التالية» وهكذا دواليك. 


للعودة الى النتيجة السابقة في البحث. 


find ~ -name ۳ 


find ^/Music -mmin -5 


find /usr -size ۷ 


find /usr/share/bug -type d 


find /usr/share/bug -type d - 


ls 


cat /etc/passwd 


more /etc/passwd 


h 


«SPACE» 


less /etc/passwd 


/bin 


اساسیات لینکس 


للخروج من صفحات الامر less‏ 

06 عرض اول عشرة أسطرء من الملف „passwd‏ 
tail‏ عرض آخر عشرة أسطرء من الملف „passwd‏ 

0 عرض أول عشرة أسطرء ولكن مع 2- سیتم عرض اول 
سطرين فقط من الملف .passwd‏ 

وا عرض قائمة بالملفات والدلائل للدلیل ete‏ ورمز الأنبوب 
| لإعادة التوجيه للأمر tail‏ لعرض آخر خمسة أسطر. 

۲۰ لانقاص‎ -n -20» لعرض الأسطر من بداية الملف‎ head 
وبالتالي‎ ./etc/passwd سطر من العدد الكلي للأسطر للملف‎ 
عرض الباقي فقط.‎ 

امر للبحث عن طریق مطابقة الاحرف. 

٥‏ امر للبحث عن سلسة احرف» وهي sshd‏ في الملف 
0 بالمسار النسبي. 

0 امر للبحث عن سلسة احرف» وهي ]۰۲00 وعلامة ^ 
تعني أن تكون الكلمة أو السلسلة في بداية السطر فقط وذلك في 
الملف passwd‏ . 

0 امر للبحث عن سلسة احرف» وهي 5۷۲0ء وذلك في 
الملف passwd‏ أياً كان موقعها بالسطر. 

grep‏ للبحث عن سلسة احرف» وهي SYNC‏ وعلامة $ تعني 
أن تكون الكلمة أو السلسلة في نهاية السطر فقط في „passwd‏ 
0 امر للبحث عن سلسة احرف» وهي حرف y‏ في اخر 


الكلمة وإظهار الحرف السابق لها في الملف „passwd‏ 


0 


head ۷0 


tail ۵۶۵ 


head -2 0 


/etc | tail -5‏ کا 


head -n -20 /etc/passwd 


fgrep 


grep sshd passwd 


grep '^root' passwd 


grep 'sync' passwd 


grep 'sync$' passwd 


grep '.y' passwd 


س0 اساسیات لینکس 


grep‏ امر Cisl‏ عن سلسة احرف. وذلك عن جميع الكلمات 
5000010101 للملف passwd‏ « وبما ان الامر 
Y grep‏ يميز الرمز ( | )ء فبالتالي سيعتبر الكلمات السابقة 
سلسلة واحدة» ويجب أن تكون جميعها في سطر واحد والا فإنه 
لن يقوم بإرجاع أي نتيجة. 

grep‏ امر للبحث عن سلسلة من الاحرف» -E‏ هو الوضع 
الموسع ليتم تميز الرمز ( | )» أي سيتم البحث عن الكلمات التالية 
sshd|root|operator‏ او احدها على الأقل. 

0 امر آخر للبحث بالوضع الموسع» عن سلسلة no‏ والتي 
تنتهي اما بالحرف b‏ او بالحرف n‏ في الملف passwd‏ وهذا 
هو الإصدار الاحدث للأمر grep.‏ وفيه يتم استخدام التعابير مثل 
(- + - ؟ -:). 

head‏ عرض اول عشرة أسطرء من الملف passwd‏ (مسار 
نسبي)» ثم إعادة توجیه النتانج الى الامر grep‏ للبحث عن 
الأرقام في المدی من 0 إلى 9 . 

م امر للبحث عن سلسلة من الاحرف» -E‏ هو الوضع 
الموسع للبحث عن مدی الأرقام من 0 إلى 9 وعرض آول 3 


خانات فقط وذلك للملف .passwd‏ 


grep ٨٩٨٧٨77 


passwd 


grep -E 'sshd|root|operator 


passwd 


egrep 'no(b|n)' passwd 


head passwd | grep '[0-9]' 


grep -E '[0-9](3 passwd 


Me 

AW‏ اساسیات لینکس 
الملحق رقم )1( 

معنی الاوامر 


معنی مفاتیح وضع الادراج 

معنی مفاتیح التحکم بالمؤشر في وضع الأوامر 

معنی آوامر الحفظ والخروج في وضع الاوامر 

لانشاء ملف برنامج نصي مع محرر V‏ 

وضع الادراج: للاخول في وضع الادراج. 

وضع الادراج: تحريك المؤشر للیمین ثم الدخول لوضع الادراج. 
وضع الادراج: لادراج سطر جديد تحت السطر الحالي. 

وضع الادراج: لادراج سطر جدید فوق السطر الحالي. 

وضع الادراج: الدخول وضع الادراج من بداية السطر الحالي. 
وضع الادراج: ستدخل في وضع الادراج في نهاية السطر 
للخروج إلى وضع الاوامر. 

وضع الاوامر: نقل الموشر سطر للاسفل. 

وضع الاوامر: نقل الموشر سطر للاعلی. 

وضع الاوامر: نقل الموشر خانة واحدة يمين السطر. 

وضع الاوامر: نقل الموشر من المکان الحالي الى يمين السطر 8 
خانات. 

وضع الاوامر: نقل المؤشر من المکان الحالي الى يمين السطر 10 
خانات. 


وضع الأوامر: نقل الموشر خانة واحدة يسار السطر. 


2230 


Command 

Insert modes key 
Cursor navigation Key 
Save & Exit command 


vi myfile 


10l 


2 

D‏ او اساسيات لینکس 

وضع الاوامر: نقل المؤشر إلى بداية الكلمة التالية في السطر. ۷ 
وضع الاوامر: نقل المؤشر إلى نهاية الكلمة الحالية. e‏ 
وضع الاوامر: نقل الموشر إلى بداية الكلمة السابقة. 0 
وضع الاوامر: نقل المؤشر إلى نهاية السطر الحالي (کمفتاح (End‏ $ 
وضع الاوامر: نقل المؤشر إلى بداية السطر الحالي (کمفتاح (Home‏ (صفر) 0 
وضع الاوامر: اكتب بدل n‏ رقم السطر الذي تريد الذهاب اليه. 3 
وضع الاوامر: الذهاب إلى السطر الثالث. 36 
وضع الأوامر: الذهاب الی السطر الأول. 1G‏ 
وضع الأوامر: الذهاب إلى السطر الأخير. G‏ 
وضع الأوامر: حذف الكلمة الموجود عندها المؤشر. dw‏ 
وضع الاوامر: التراجع عن العملية الأخيرة. 0 
وضع الأوامر: حذف كلمتين منتالیتین» بداية من الكلمة الموجود عندها 2dw‏ 
المؤشر والتي تليها. 

وضع الأوامر: حذف آربعة خانات» بداية من الخانة التي بها المؤشر. XXXX‏ 
وضع الاوامر: التراجع عن العمليات الاربعة الاخيرة. 4u‏ 
وضع الاوامر: حذف 14 خانة بداية من الخانة التي بها المؤشر. ×14 
وضع الاوامر: حذف 5 خانات قبل المؤشر ( يسار المؤشر). 5X‏ 
وضع الأوامر: حذف سطر الحالي كاملا. dd‏ 
وضع الأوامر: لصق ما تم حذفه» کالسطر المحذوف بالخطوة السابقة. م 
وضع الأوامر: التراجع عن العمليتين الأخيرة. 20 
وضع الأوامر: حذف سطرين» الحالي والذي يليه. 200 
وضع الاوامر: نقل المؤشر إلى بداية الكلمة الرابعة في السطر الحالي. 4w‏ 


وضع الأوامر: 


E 


وضع الاوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 


وضع الأوامر: 


(text كلمة‎ 


وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 
وضع الأوامر: 


وضع الأوامر: 


وضع الأوامر 


الادراج 


حذف الخانات من المكان وجود المؤشر إلى نهاية 


ضم سطرين» الحالي والذي يليه. 

نسخ الكلمة الموجود بها المؤشر. 

لصق ما تم نسخه سابقاً. 

ضم 3 اسطر معا بداية من الحالي ثم ما يليه. 


البحث عن كلمة text‏ ثم حذفها (اضف مسافة قبل وبعد 


تغيير حالة الأحرف من صغير الى كبير والعكس. 
لحفظ الملف. 

Eia‏ ,35461 اعت 

للكتابة علی ملف والخروج. 

للكتابة على ملف للقراءة فقط إن كان ممكناً والخروج. 
حفظ وإغلاق (لاحظ عدم استخدام النقطتين : ) 
الخروج من غير حفظ. 

تجاهل التغييرات وتحميل الملف مجدداً. 

للكتابة على ملف للقراءة فقط إن كان ممکناً 

البحث عن كلمة line‏ 


الانتقال الى نتيجة البحث التالية. 


البحث للخلف ( ما قبل الموضع الحالي) عن كلمة line‏ 


استبدال الكلمة الحاليةء فيتم حذفها والدخول لوضع 


آمر لتشغيل الملف sample.sh‏ . 


ل3 


:96s/ text //g 


bash sample.sh 


اساسیات لینکس 


ملاحظة: يجب ان يحتوي الملف على الجملة #!/bin/bash‏ 

/, أمر آخر للتشغيل» للملف .sample.sh‏ 

X لتغيير الاذونات» ۾ لجميع المستخدمين» + إعطاء إذن»‎ chmod 
(مسار نسبي).‎ sample.sh التنفیذء على الملف‎ 

قراءة المتغير المسمى باسم age‏ 

-lt جملة اختبارء 5306 هو متغیر»‎ test جملة إذا الشرطيةء‎ if 
.٠١ بمعنى أن المتغير 8206 اقل من‎ .٠١ اصغر من الرقم‎ 

النتيجة إذا كانت جملة الاختبار صحيحة. 

©5 غير ذلك» بمعنی إذا كانت النتيجة خاطئة. 

نهاية جملة إذا الشرطية. 

طريقة أخرى لاستدعاء جملة الاختبار test‏ بوضع الشرط dah‏ 
الاقواس المربعة مع ترك مسافة بين القوسين. 

ملاحظة: سوآءا تحقق الشرط أو لم يتحقق فان برنامج jf‏ ينتهي بعد 
الإدخال الأول. 

6 جملة للتكرارء والأقواس المربعة [ ]هي لاستدعاء أمر الاختبار 
test‏ (طريقة أخرى لكتابة جملة الاختبار)ء و $num‏ هو متغير يتم 
إدخاله من قبل المستخدم» 100 وا تعني أن الرقم مساوي أو أصغر من 
0. لاحظ أن التكرار مرتبط بتحقق الشرط فإذا لم یتحقق تستمر 
الحلقة» وإذا تحقق ينتهي البرنامج. 

طالما الشرط متحقق» افعل التالي. 

نهاية التكرار عند تحقق الشرط. 

إجراء مجموعة من العمليات على سطر الأوامر. 


قائمة من قيم الاعداد الصحيحة. 


.sample.sh 
cal 


chmod a+x sample.sh 


read age 


if test $age - 16 


then 
else 
fi 


if ] 5206 -lt 16 ] 


while [ $num -le 100] 


do 
done 
for 


seq 


اساسیات لینکس 


الملحق رقم (۷) 
ملخص لأوامر المعمل العاشر: 


المعنی 

عرض تفاصیل وحدة المعالجة. 

cat‏ أمر عرض المحتويات» للملف cpuinfo‏ والذي يحتوي على 
تفاصیل وحدة المعالجة. 

٥‏ اکتشاف مقدار الذاكرة RAM‏ و - بالكيلوبايت. 

٥‏ اکتشاف مقدار الذاكرة -m ; «RAM‏ بالميجابايت. 

٥‏ اكتشاف مقدار الذاكرة «RAM‏ وں- بالجيجابايت. 

عرض الأجهزة المتصلة بنواقل PCI‏ 

عرض الأجهزة المتصلة بنواقل «PCI‏ - لإظهار مشغل النواة 
والوحدات المستخدمة. 

عرض أجهزة usb‏ المتصلة 

يقوم بسرد قائمة بالأجهزة devices‏ في النظام. 

ملاحظة: لا يعمل الأمر ]8108] عادة في البيئة الافتراضية VM‏ 
عرض وحدات يتم تحميلها حالیا. 

يقوم بقراءة وطباعة المعلومات من .SMBIOS‏ 

fdisk‏ لسرد محركات الأقراص» -C‏ فيقوم بمنع طباعة التحذيرات 
التوافق u «DOS‏ لعرض وحدات التخزين على شكل قطاعات بدلا 


من اسطوانات. أما | فهو لإظهار المحركات بشكل غير تفاعلي. 


۰ء 


Command -option string 
نام کا‎ 


cat /proc/cpuinfo 


free -k 
free -m 
free و-‎ 
lspci 


lspci -k 


lsusb 


lshal 


lsmod 
dmidecode 


fdisk -cul 


GD‏ اساسیات لينكس 


الملحق رقم )^( 


المعنی 

وا عرض uad‏ بالملفات الموجودة في الدلیل /proc‏ 

cat‏ عرض محتویات لسطر الأوامر cmdline‏ للعملية رقم 
(1) والموجودة في دلیل العملیات [proc‏ . 

معلومة: العملية الأولى خاصة san‏ التشغیل وهي /sbin/init‏ 
ps‏ عرض العملیات قید التشغیل؛ والخیار -p‏ لتحدید رقم العملية 
التي نرید عرضها وهي العملية رقم 1. 

cat‏ عرض محتويات» لسطر الأوامر cmdline‏ والموجودة 
في دلیل العملیات /proc‏ .وهي المعطیات التي نم تمريرها للنواة 
وقت التمهید. 

ping‏ بقوم باختبار الاتصال. للجهاز «localhost‏ ثم توجیه 
ال خراج القياسي إلى الملف /dev/null‏ ویعتبر كسلة للمحذوفات. 
ملاحظة: العملية السابقة تعمل في المقدمة وبالتالي لا نستطیع کتابة 
أي آمر في موجه الأوامر الا اذا قمنا بایقاف أو إنهاء تلك العملية. 
إنهاء العملية أو الوظيفة التي تعمل بالمقدمة بشكل نهائي وليس 
للإيقاف. واستعادة السيطرة على النافذة الطرفية. 

ping‏ يقوم باختبار الاتصال. للجهاز ۰۱001۳0051 ثم توجيه 
الإخراج القياسي إلى الملف ٣1‏ 06۷/7/؛ أما الرمز & فهو لجعل 
الامر يعمل الخلفية. وبالتالي نستطيع الكتابة في موجه الأوامر. 


معرفة أرقام الوظائف قيد التشغيل» وتأتي بين قوسين مربعة [ ] . 


Command -option string 
ls /proc 


cat /proc/1/cmdline; echo 


ps -p 1 


cat /proc/cmdline 


ping localhost » /dev/null 


Ctrl-c 


ping localhost < /dev/null & 


jobs 


5 
ww‏ 
7 اساسیات لینکس 


.1 احضار للمقدمة للوظيفة الاولی ذات الرقم‎ fg 
ملاحظة: يستخدم الرمز % مع الوظائف ولیس مع العملیات.‎ 
إيقاف الوظيفة التي بالمقدمة (ولیس انهانها) واستعادة السيطرة‎ 
على النافذة الطرفية.‎ 

.2 إحضار للمقدمة للوظيفة الثانية ذات الرقم‎ fg 

.1 إرجاع للخلفء للوظيفة الأولى ذات الرقم‎ bg 
.3 امر للاٍنهاء» وذلك للوظيفة الثالثة ذات الرقم‎ Kill 

Ul‏ الرمز 96 فيستخدم للتفريق بين إنهاء الوظيفة أو إنهاء العملية. 
1 اأمر لإنهاء الجميع (من نوع واحد) c‏ وهنا يستخدم 
لإنهاء الأوامر التي من نوع ping‏ . 
برنامج تفاعلي لإدارة العمليات» وبالتالي إصدار الأوامر داخله. 
في الشاشة التفاعلية Jah‏ 100: لانهاء عملية من العمليات. 

في الشاشة التفاعلية Jah‏ م0]: رقم العملية التي نريد إنهائها. 
في الشاشة التفاعلية داخل top‏ لانهاء العملية مع إرسال الاشارة 
الافتراضية رقم ]15[ اضغط على مفتاح إدخال .Enter‏ 
وتستخدم تلك الإشارة لتحديد طريقة الإنهاء. 

في الشاشة التفاعلية داخل 00]: لإنهاء العملية مع إرسال إشارة 
غير الافتراضية وهي رقم 9 تعتبر إشارة قوية لا يمكن تجاهلها. 
للخروج من الأمر op‏ 

0 عمل نقطة توقف pause‏ لأحد برنامج القشرة وذلك 
لفترة محددة من الزمن» و 888888 هو المكان الذي نريد 
إيقافه» و رمز .8 لجعل العملية تعمل في الخلفية. 


عرض بعض العمليات قيد التشغيل. 


۲ 


fg %1 


Ctrl+z 


fg 962 


bg %1 


kill %3 


Killall ping 


top 


99 


Kill PID with signal [15] 


Kill PID with signal [15]:9 


q 


sleep 888888 & 


ps 


A‏ اساسیات لینکس 


.103 PID امر انهاء. للعملية ذات المعرف رقم‎ Kill 

1 أمر انهاء برنامج» وذلك بكتابة اسم البرنامج الذي نريد 
إنهائه وهو Ul «sleep‏ رقم ٥١‏ فهو إشارة ترسل مع الأمر 
وذلك لتحدید طريقة الإنهاء. 

ps‏ آمر عرض العمليات قید التشغيل؛ أما -e‏ فهو لعرض كافة 
العمليات. 

ps‏ آمر عرض العمليات قيد التشغيل؛ و 0- لتحديد الأعمدة التي 
نريد عرضها. حيث أن لام٥‏ هو عامود جديد غير الأعمدة 
الافتراضية الأربعة الباقیة, 

وم آمر عرض العمليات قيد التشغیل؛ و 0- لتحديد الأعمدة التي 
نرید عرضها وهي pid,tty,time,26mem,cmd‏ « وأخيراً 
الامر sort‏ لفرز الأعمدة تنازلياً حسب العامود mem‏ 

RAM اکتشاف مقدار الذاكرة‎ free 

su‏ تبديل المستخدم» root.‏ — الى المستخدم الجذر» وسيطلب 
النظام كلمة مرور للدخول إلى الحساب. 

الأمر 551 (يستخدم لتسجیل الدخول عن بعد)» وهنا نستخدمه 
لتولید بیانات تسجیل الدخول (الناجحة والفاشلة) في ملف 
var/log/auth.log/‏ . 

tail‏ آمر عرض آخر 10 أسطرء و 5- لعرض خمسة أسطر 
فقط من الملف على 30111.16 وسیتم عرض محاولات تسجیل 
الدخول والتي تمت بواسطة الأمر ssh‏ السابق. 

0 برنامج للتنصیب او للإزالة ویستخدم ايضاً في 


المهام المجدولة» -e‏ للتعدیل على السجل. 


kill 3 


pkill -15 sleep 


ps -e 


ps -o pid,tty,time,gecpu,cmd 


ps -o 


pid,tty,time,g6mem,cmd -- 


sort 77 


free 


su — root 


ssh localhost 


tail -5 /var/log/auth.log 


crontab -e 


س0 اساسیات لینکس 


هذا الامر یقوم بعملية جدولة كالتالي: الرقم الأول للدقائق» والثاني 
للساعات» والثالث لترتیب اليوم في الشهر» والرابع للشهرء 
والخامس لترتیب اليوم في الأسبوع» و الأمر WhO‏ فهو لعرض 
المستخدمین الحاليين للنظام» و << لاعادة توجیه البيانات السابقة 
مع الاحتفاظ بما يوجد في الملف whothere‏ الموجود في 
المسار المطلق Amp/whothere‏ . 

0 برنامج للتنصيب او للإزالة ويستخدم ايضاً في 
المهام المجدولة» ]- لعرض محتويات السجل ولكن في شاشة 
الإخراج القياسي (stdout)‏ ورمز | خاص بتحويل المخرجات» 
الى الأمر 2- tail‏ والذي سيعرض آخر سطرين من السجل. 
tail‏ عرض آخر ۱۰ أسطرء من السجل 0101.100 والموجود 
بالمسار المطلق Ivar/log/cron.log‏ . 

0 أمر للحصول على امتيازات الجذر» 5- tail‏ عرض 
آخر خمسة أسطرء من الملف cron.log‏ والموجود بالمسار 
المطلق Ivar/log/cron.log‏ . 

9 څأر لتحديث ذاكرة التخزین cache‏ و الروابط 
الرمزية» -p‏ يعرض قائمة المكتبات المشترکةء ورمز | فهو 
لاعادة less eas sil‏ أمر للعرض على شكل صفحات. 

0 طباعة المكتبة المشتركة وما يتبعهاء للملف bash‏ القابل 


للتنفیذ والموجود بالمسار المطلق /bin/bash‏ . 


02 * * 0 who << 


Atmp/whothere 


crontab -۱ | tail -2 


tail /var/log/cron.log 


sudo tail -5 


Ivar/log/cron.log 


ldconfig -p | less 


ldd /bin/bash 


اساسیات لینکس 


الملحق رقم (۹) 
ملخص لأوامر المعمل الثاني عشر: 


المعنی 

عرض عنوان الجهاز (بروتوكول الانترنت (IP.‏ 

عرض معلومات جدول التوجیه 

6 عرض جدول -n eus sil‏ للعرض على شكل أرقام. 
grep‏ أمر بحث عن سلسلقه وهي عنوان 127.0.0.1 في الملف 
56 والموجود في المسار المطلق letc/hosts‏ . 

09 أمر اختبار اتصال» -c‏ قم بوقف الاختبار بعد ارسال 4 حزم 
«packets‏ للجهاز localhost‏ . 

cat‏ عرض محتویات. الملف reslov.conf‏ والموجود بالمسار 
المطلق nameserver 33 l /etc/reslov.conf‏ 

e IP خاص بالبحث لإعادة تحويل الاسم إلى عنوان‎ ul dig 
. localhost.localdomain 

ex |ء‎ ٣١ آمر خاص بالبحث لإعادة تحويل الاسم إلى عنوان‎ dig 
. cserver.example.com 

-X «IP. عادة تحويل الاسم إلى عنوان‎ y آمر خاص بالبحث‎ dig 
. 192.168.1.2 لعکس العملية وتحويل عنوان ۳| إلى اسم للعنوان‎ 
والذي يحتوي على قائمة‎ services لعرض المحتویات. للملف‎ cat 
بأسماء وارقام المنافذ.‎ 
للحصول على‎ --help لعرض معلومات عن الشبكة»‎ 1 


استخدامات الامر „netstat‏ 


Command -option string 


Ifconfig 


route 


route -n 


grep 127.0.0.1 /etc/hosts 


ping -c4 localhost 


cat /etc/reslov.conf 


dig localhost.localdomain 


dig cserver.example.com 


dig -x 192.168.1.2 


cat /etc/services 


netstat --help 


A‏ اساسیات لینکس 


1 لعرض معلومات عن الشبکة 1 خاص بمنافذ ۰۲٣٣‏ | 
لمعرفة حالة الاستماع» وبعبارة أخرى معرفة ما اذا كانت منافذ 

۳ تقوم بالاستماع إلى اتصال وارد أو لا. 

| »[ 06 لعرض معلومات عن الشبكةء 1 خاص بمنافذ‎ netstat 
لمعرفة حالة الاستماع » و لإحضار النتائج على شكل أرقام وليس‎ 
تقوم‎ TCP رموز. وبعبارة أخرى معرفة ما اذا كانت منافذ‎ 
بالاستماع إلى اتصال وارد أو لا.‎ 

1 لعرض معلومات عن الشبكةء 1- لعرض قنوات الاتصال 
56 لطبقة cp‏ 

1 لعرض معلومات عن الشبكةء -U‏ لعرض قنوات الاتصال 
56 لطبقة .udp‏ 

1 لعرض معلومات عن الشبکة -w‏ لعرض قنوات الاتصال 
„raw ài! sockets‏ 

1 لعرض معلومات عن الشبكة» -X‏ لعرض قنوات الاتصال 
sockets‏ لطبقة „unix‏ 

15 لعرض معلومات عن الشبكة» -a‏ لعرض جمیع قنوات 
الاتصال sockets‏ سوآءا في حالة استماع أو لا. 

1 لعرض معلومات عن الشبكةء |- للاستماع الى احد المنافذ. 
1 لعرض معلومات عن الشبكةء -n‏ للعرض على شكل ارقام. 
netstat‏ لعرض معلومات عن -numeric-hosts ASil‏ 
عرض عناوين المضیف على شكل ارقام» دون التأثیر على اسم المنفذ 


أو المستخدم. 


netstat -tl 


netstat -tln 


netstat -t 


netstat -u 


netstat -w 


netstat -x 


netstat -a 


netstat -l 


netstat -n 


netstat --numeric-hosts 


اساسیات لینکس 


--numeric-ports ASil لعرض معلومات عن‎ netstat 
عرض المنافذ على شكل ارقام» دون التأثیر على اسم المضیف أو‎ 
أسماء المستخدمين.‎ 

--numeric-users لعرض معلومات عن الشبکةه‎ netstat 
عرض معرفات المستخدم على شكل ارقامء دون التأثير على اسم‎ 
المضيف أو أسماء المنفذ.‎ 

1 لعرض معلومات عن الشبكةء -N‏ عرض أسماء العتاد. 
1 لعرض معلومات عن الشبكة» -e‏ عرض معلومات إضافية. 
netstat‏ لعرض معلومات عن الشبكة» 0- عرض المعلومات 
والمتعلقة بالمؤقت الشبكي .hetworking timers‏ 

1 لعرض معلومات عن الشبكة -p‏ لعرض رقم العملية PID‏ 
وأيضا اسم البرنامج الذي ينتمي إليه كل مأخذ توصيل „socket‏ 
1 لعرض معلومات عن الشبكةء -y‏ اعرض الحدث. 
1 لعرض معلومات عن الشبكة» -C‏ طباعة المعلومات المحددة 
كل ثانية بشكل متواصل. 

1 لعرض معلومات عن الشبكةء -r‏ لعرض جدول التوجيه. 
netstat‏ لعرض معلومات عن الشبكة» -j‏ لعرض الواجهات 
(interfaces)‏ 

1 تعرض معلومات عن الشبكة» -g‏ عرض معلومات عضوية 
مجموعة البث المتعدد multicast‏ ل ۱۳۷4 و ۱۳۷6 

1 لعرض معلومات عن (ASIA‏ /|-عرض قائمة باتصالات 
0 (برنامج اتصال بلينكس مشابه لنظام (1:many‏ 
netstat‏ لعرض معلومات عن الشبكة» -s‏ عرض تلخيص 


بإحصائيات كل بروتوكول. 


netstat --numeric-ports 


netstat --numeric-users 


netstat -N 


netstat -e 


netstat -o 


netstat -p 


netstat -v 


netstat -c 


netstat -r 


netstat -i 


netstat -g 


netstat -M 


netstat -s 


ES‏ اساسیات لینکس 


1 لعرض معلومات عن الشبكةه -W‏ عدم اقتطاع عناوین IP‏ 
باستخدام تقنية " إخراج واسع حسب الحاجة ". 

1 لعرض معلومات عن الشبكة» -F‏ طباعة جدول معلومات 
التوجيه من (Forwarding Information Base : FIB)‏ 
1 لعرض معلومات عن الشبكة» -C‏ طباعة معلومات التوجیه 
من ذاكرة الطرق الموجودة في Ya cache‏ من .FIB‏ 


۲ لعرض معلومات عن الشبكة» ۷- للإصدار. 


2750 


netstat -W 


netstat -F 


netstat -C 


netstat -V 


ام 


E We 
اساسيات لینکس‎ AW 


الملحق رقم (۱۰) 
ملخص لارامر تل ال عقت 


المعنی Command -option string‏ 
head‏ عرض أول 10 أسطر من ملف passwd‏ والموجود 0 630 

بالمسار المطلق /etc/passwd‏ » والخاص بحسابات 
المستخدمین و النظام. 

grep ۷ ۵ امر للبحث عن سلسلة من الاحرف» وهي المستخدم‎ grep 
والموجود بالمسار المطلق‎ passwd في الملف‎ sysadmin 
/ 060 

1 استرجاع معلومات من قاعدة بيانات او الملف» وهو passwd sysadmin‏ 061601 
0 والخاص بحسابات المستخدمین» حول المستخدم 
.sysadmin‏ 

man 5 passwd للبحث في صفحات دلیل المستخدم» ورقم 5 يعني‎ man 
البحث داخل القسم رقم 5 ء وأخيرا الكلمة التي نريد البحث عنها‎ 
.passwd 

id عرض معلومات الهوية لحساب مستخدم وإذا لم يكتب أي‎ id 


شيء بعد الأمر فستظهر معلومات الهوية الخاصة بالمستخدم 


الحالي للنظام. 
id‏ عرض معلومات الهوية لحساب مستخدم» وهو أ۲)00. id root‏ 
getent‏ استرجاع معلومات من قاعدة بيانات او الملف» وهو getent group sysadmin‏ 


.Sysadmin والخاص بالمجموعات» حول المجموعة‎ group 


A‏ اساسیات لینکس 


getent‏ استرجاع معلومات من قاعدة بیانات او الملف» وهو 
group‏ والخاص بالمجموعات» حول المجموعة „adm‏ 

عرض اسم المستخدم الحالي للنظام. 

5 لعرض المجموعات التي ينتمي إليها مستخدم وإذا لم 
يكتب أي شيء بعد الأمر فستظهر المجموعات الخاصة 
بالمستخدم الحالي للنظام. 

5 لعرض المجموعات التي ينتمي إليها مستخدم» وهو 
.root‏ 

٥‏ أمر للحصول على القائمة الحالية من المستخدمين 
المتواجدین علی النظام. 

۷ الأمر للحصول على عرض أكثر تفصیلا للمستخدمین الذین 
هم حالیا على النظام الخاص بك 

0 أمر لتعدیل تکوینات الأمر sudo‏ وذلك بغرض 
السماح للمستخدمین بالوصول إليه و استخدامه. 

الدخول للأمر visudo‏ یکون عن طریق حساب الجذر. 
لاحظ أن الأمر سیفشل إذا لم يكن المستخدم هو ۲001. 

su‏ آمر تبدیل المستخدمین وذلك بكتابة اسم المستخدم بعد - ء 
إذا لم یتم كتابة أي شيء بعد - فهذا يعني الانتقال الى حساب 
.root‏ 

0 أمر لتعدیل تكوينات الأمر sudo.‏ وذلك بغرض 
السماح للمستخدمین بالوصول إليه واستخدامه. 

الدخول للأمر visudo‏ يكون عن طریق حساب الجذر. 


لاحظ أن الأمر سينجح إذا کان بحساب المستخدم أ۲00. 


£Y. 


getent group adm 


whoami 


groups 


groups root 


who 


visudo 


SU - 


visudo 


AW‏ اساسیات لینکس 


exit‏ آمر للخروج من الحساب الحالي» وهنا سيتم الخروج من 
حساب الجذر الى حساب المستخدم Sysadmin‏ 

0 عرض أول 10 أسطر من ملف shadow‏ و الموجود 
بالمسار المطلق /etc/shadow‏ « و 3- يعني عرض أول 
ثلاث اسطر فقط. من الملف shadow‏ والذي يحتوي على 
کلمات السر المشفرة. 

الأمر السابق سیفشل sysadmin o‏ لیس له صلاحیه عرض 
الملف shadow‏ . 

وا عرض قانمة بالملفات والدلائلء و l‏ لاعطاء التفاصیل» 
للكائن «shadow‏ لاحظ أن الاستعراض من المکان الحالي ولا 
نحتاج الى الانتقال إلى ذلك الکائن, 

0 آمر للحصول على امتیازات الجذر» head‏ لعرض 
آول 10 أسطر من ملف shadow‏ والموجود بالمسار المطلق 
۷ و 3- يعني عرض آول ثلاثة اسطر فقط. 
من الملف shadow‏ والذي يحتوي على کلمات السر المشفرة. 
الأمر السابق سینجح لأن sysadmin‏ سیستخدم صلاحیات 


الجذر بواسطة الأمر sudo‏ 


exit 


head -3 /etc/shadow 


ls - ۸۷ 


sudo head -3 ۷ 


س0 اساسيات لينكس 


الملحق رقم (۱۱) 
ملخص لأوامر المعمل الرابع عشر: 


المعنی 
su‏ آمر تبديل المستخدمين وذلك بكتابة اسم المستخدم بعد - c‏ إذا 
لم يتم كتابة أي شيء بعد - فهذا يعني الانتقال الى حساب ۲001. 
008 أمر انشاء مجموعة؛ -r‏ يجعل معرف المجموعة 
GID‏ في النطاق المحجوز بین ۰4۹۹-۱ وأخيراً اسم المجموعة 
وهو research‏ . 

groupmod‏ للتعدیل على مجموعة وخيار -n‏ لتغيير اسم هذه 
المجموعة الى الاسم run‏ وذلك للمجموعة research‏ 
groupmod‏ للتعدیل على مجموعة وخیار -g‏ من أجل تغيير 
معرف المجموعة GID‏ ثم بعد ذلك المعرف الجديد الذي تريده وهو 
علی سبیل المثال 11 ثم اسم المجموعة, 

groupdel‏ لحذف مجموعة طالما آنها ليست مجموعة أساسية 
لمستخدم» ثم بعد ذلك اسم المجموعة التي تريد حذفها. 

1 استرجاع معلومات من قاعدة بيانات او الملف» وهو 
group‏ والخاص بالمجموعات» حول المجموعة research‏ 
0 أمر تعديل على مستخدم» 2- لإضافة المستخدم الى 
مجموعة» G‏ لجعلها مجموعة ثانوية cA]‏ ثم اسم المجموعة 
17ء وأخيراً المستخدم .Sysadmin‏ 

6 أمر تعديل على مستخدم» 2- لإضافة المستخدم الى 


مجموعةء G‏ لجعلها مجموعة ثانوية cal‏ ثم اسم المجموعة A‏ 


Command -option string 


SU - 


groupadd -r research 


groupmod -n run research 


groupmod -g 11 research 


groupdel 


getent group research 


usermod -aG research 


sysadmin 


usermod -aG A,B 


sysadmin 


س0 اساسیات لینکس 


ونستخدم علامة الفاصلة " , " لاضافة مجموعة تانوية أخرى وهي 
B‏ وذلك للمستخدم .sysadmin‏ 

606 مر تعدیل على مستخدم» G‏ لإضافة المستخدم الى 
مجموعة ثانوية وحذف جميع المجموعات الثانوية السابقة» ثم اسم 
المجموعة X‏ وذلك للمستخدم sysadmin‏ لاحظ ان عدم 
استخدام الخیار 2 سیحذف جمیع المجموعات الثانوية السابقة, 
groups‏ لعرض المجموعات التي ينتمي الیها مستخدم» و هو 
.sysadmin‏ 


.Sysadmin عرض معلومات الهوية لحساب مستخدم» وهو‎ id 


1 استرجاع معلومات من قاعدة بیانات او الملف» وهو 
group‏ والخاص بالمجموعات» حول المجموعة research‏ 
0 أمر لانشاء مستخدم جدیدء -G‏ لجعله عضو ثانوي في 
المجموعة -C «research‏ لوضع تعليق وهو اسم المستخدم 
الکامل والذي بظهر في الواجهة الرسومية وهو هنا 'Linux‏ 
1ء -m‏ لإنشاء دليل رئيسي لهذا المستخدم» وأخیراً اسم 
هذا المستخدم الجديد .Student‏ 

1 استرجاع معلومات من قاعدة بیانات او الملف» وهو 
group‏ والخاص بالمجموعات» حول المجموعة research‏ 
1 استرجاع معلومات من قاعدة بيانات او الملف» وهو 
group‏ والخاص بالمجموعات» حول المجموعة .Student‏ 

1 استرجاع معلومات من قاعدة بيانات او الملف» وهو 
0 والخاص بحسابات المستخدمین» حول المستخدم 


.student 


usermod -G X sysadmin 


groups sysadmin 


id sysadmin 


getent group research 


useradd -G research -c 


'Linux Student' -m student 


getent group research 


getent group student 


getent passwd student 


س0 اساسیات لینکس 


1 استرجاع معلومات من قاعدة بیانات او الملف» وهو 
shadow‏ والخاص بكلمات المرور» حول المستخدم „Student‏ 
لاحظ ظهور الرمز! في الحقل الثاني وذلك لعدم تعيين كلمة مرور 
للمستخدم .Student‏ 

تعيين باسورد للمستخدم student‏ 

1 استرجاع معلومات من قاعدة بيانات او الملف» وهو 

۷ والخاص بكلمات المرور» حول المستخدم .Student‏ 
last‏ لمعرفة ما إذا کان المستخدم قد قام بتسجيل دخول في النظام» 
وإذا لم يُكتب اسم المستخدم iia‏ الأمر على المستخدم الحالي 
للنظام. 

1 لمعرفة ما إذا کان المستخدم قد قام بتسجيل دخول في النظام» 
ثم اسم المستخدم وهو .Student‏ 

0 يُظهر محاولات تسجیل الدخول الى النظام حتى الفاشلة. 
0 لتعديل على مستخدم» -L‏ یستعمل لحجب أو قفل 
الحساب وبالتالي لا يستطيع المستخدم الدخول على النظام؛ وأخيراً 
اسم المستخدم student‏ ويمكن فك الحجب بنفس الأمر السابق 
ولكن مع الخيار -U‏ كما يلي. 

60 امر تعديل على مستخدم» -U‏ لفك الحجب وبالتالي 
يستطيع المستخدم الدخول إلى النظامء وأخیراً المستخدم „student‏ 
6 لحذف حساب مستخدم» ثم اسم المستخدم الذي تريد 
حذفه وهو في هذا المثال .Student‏ 

6۱ لحذف حساب مستخدم» ۲- لحذف الدليل الرئيسي 


والبرید للمستخدم» ثم اسم المستخدم الذي تريد حذفه „Student‏ 


getent shadow student 


passwd student 


getent shadow student 


last 


last student 


lastb 


usermod -L student 


usermod -U student 


userdel student 


userdel -r student 


A‏ اساسیات لینکس 


الملحق رقم (۱۲) 


المعنی Command -option string‏ 
0 مر انتقال الى مسار ماء وهو الدليل cd /tmp . Amp‏ 
mkdir‏ لانشاء دلیل» و priv-dir‏ هو اسم الدليل الأول» و mkdir priv-dir pub-dir‏ 


pub-dir‏ هو اسم دلیل ثاني. 

ملاحظة: يستطيع الأمر mkdir‏ انشاء عدد من الدلائل بخطوة 
واحدة بشرط وجود مسافة بین أسمائهم. 

آمر touch‏ له وظيفتين» الأولى تحديث ملف موجود بهذا touch pub-dir/pub-file‏ 
الاسم» أو إنشاءه إذا لم يجد الملف» فيتم هنا إنشاء ملف باسم 
pub-file‏ داخل الدليل .pub-dir‏ 

ها عرض قائمة بالملفات والدلائل» و ]- لإعطاء التفاصیل. ls -l pub-dir‏ 
للدليل «pub-dir‏ لاحظ أن الاستعراض من المكان الحالي ولا 
نحتاج الى الانتقال إلى ذلك الكائن. 

chmod o-rx priv-dir/ لتغییر الانونات» م للآخرينء - إزالة إذن» ۲ القراءة‎ chmod 
علامة / والتي بعد اسم‎ Ul cqpriv-dir و × التنفیذء على الملف‎ 
الدليل فهي اختيارية للدلالة على أنه دلیل.‎ 

وا عرض قائمة بالملفات والدلائل» و -l‏ لاعطاء التفاصیل» ول -ld pub-dir/‏ کا 
لعرض تفاصیل الدلیل نفسه ولیس ما بداخله. «pub-dir JAW‏ 


ul‏ / والتي بعد اسم الدلیل فهي اختيارية للدلالة على أنه دلیل. 


¿yO 


A‏ اساسیات لینکس 


W «(3 لتغيير الاذونات»  للآخرینء + اعطاء‎ chmod 
الکتابة» على الملف 2-01۳ دان؛ أما علامة / والتي بعد اسم‎ 
الدلیل فهي اختيارية للدلالة على أنه دلیل.‎ 

۲ لتغيير الاذونات» و للمجموعة - إزالة إذن»‎ chmod 
0 القراءة» وس الكتابقه وعلامة " , " لإضافة اذونات جدیدة» و‎ 
.priv-dir للآخرینء - إزالة اِذن» ۲ القراءة» على الملف‎ 

وا عرض قائمة بالملفات والدلائل» و ]- لاعطاء التفاصیل. 
للملف «pub-file‏ والموجود في المسار .pub-dir/pub-file‏ 
06 لتغییر الاذونات» a‏ لكافة المستخدمين «(0,g,U)‏ = 
اعطاء إذن» ۲ القراءة» وس الکتابة» على الملف «pub-dir‏ 
والموجود في المسار .pub-dir/pub-file‏ 

لاحظ سيتم حذف الاذن الذي لم يُذكر(التنفيذ (x‏ من الجمیع. 
chmod‏ لتغییر الاذونات» ں للمالك» = اعطاء اذن» X‏ التنفیذ 
على الملف ۰0۱0-0۲ والموجود في المسار pub-dir/pub-‏ 
file‏ لاحظ سیتم حذف الأذونات الذي لم ثُذكر (W « r)‏ من 
المالك فقط وبدون أي تغيير على البقية (المجموعةء الاخرین). 
0 يقوم بالإخراج على الشاشة للأمر "date"‏ وعلامة 
التوجیه < تعني إعادة توجیه الأمر إلى الملف test.sh.‏ 

. test.sh تشغیل, للملف‎ Al ,/ 

60 لتغییر الاذونات» y‏ للمالك» + اعطاء اذن» × التنفیذ» 
على الملف test.sh‏ . 


. 1651.6 آمر عرض القيمة الثمانية للانونات» للملف‎ stat 


chmod o-w pub-dir/ 


chmod g-rw,o-r priv-dir/priv- 


file 


ls -l pub-dir/pub-file 


chmod a=rw pub-dir/pub-file 


chmod u=x pub-dir/pub-file 


echo "date" > test.sh 


Jtest.sh 


chmod u+x test.sh 


stat test.sh 


PA:‏ اساسیات لیکن 


0 لتغییر الاذونات» والأرقام هي القيمة الثمانية للانونات» 
حیث أن أول ۷ خاصة بالمالك وتعني قراءة وكتابة وتنفيذ (4+۲+۱) 
وثاني V‏ خاصة بالمجموعة وتعني قراءة وكتابة وتنفيذ (4+۲+۱) 

و ٥‏ خاصة بالآخرین وتعني قراءة وتنفيذ (4+۱) للملف test.sh‏ 
su‏ أمر تبديل المستخدمين وذلك بكتابة اسم المستخدم بعد - » 
وإذا لم يتم كتابة اسم بعد - فهذا يعني الانتقال الى حساب root‏ 
0 لتغيير المالك والمجموعة للكائن» إلى المستخدم 
root‏ و مجموعة root‏ للملف pub-dir‏ 

0 تغيير المالك والمجموعة ء إلى المستخدم «bin‏ 
(وحيث أنه لم یتم ذكر المجموعة فلن يتم تغيرها) للملف pub-‏ 
file‏ . 

0 لتغيير المجموعة فقط » -R‏ تعني بشكل متكرر 
وبالتالي سيتم تغير المجموعة للدليل ولكل الملفات والأدلة 


الفرعية التي بداخلهء إلى المجموعة «users‏ للدليل priv-dir‏ 


230 


chmod 775 105 


chown root:root pub-dir 


chown bin pub-dir/pub-file 


ls -l pub-dir/pub-file 


chgrp -R users priv-dir 


س0 اساسیات لینکس 


الملحق رقم (۱۳) 


المعنی 
[s‏ عرض قائمة بالملفات والدلائل و -l‏ لاعطاء التفاصیل ول 
لعرض تفاصیل الدلیل نفسه ولیس ما بداخله للدليل /tmp‏ . 
لاحظ وجود t‏ في الأذونات وهي إذن البت اللاصق «Sticky bit‏ 
والذي یتیح الاضافة والتعدیل ولکن الحذف خاص بمنشئ الملف. 
[s‏ عرض قائمة بالملفات والدلائل و -l‏ لاعطاء التفاصیل» ول 
لعرض تفاصيل الدلیل نفسه ولیس ما بداخله للدليل lvar/tmp‏ . 
لاحظ وجود t‏ في الأذونات وهي إذن البت اللاصق «Sticky bit‏ 
والذي يتيح الاضافة والتعدیل ولکن الحذف خاص بمنشئ الملف. 
Ls‏ عرض قائمة بالملفات والدلائل و -l‏ لاعطاء التفاصیل» 
للملف shadow‏ (ویوجد به کلمات السر المشفرة للمستخدمین). 
[s‏ عرض قائمة بالملفات والدلائل» و -l‏ لاعطاء التفاصیل, للأمر 
0 (لاحظ وجود حرف ] في الأذونات وهو إذن 
0 وبلتالي سیتم تنفیذ الأمر passwd‏ من قبل المستخدم 
الفعلي المُشغل للامر وکأنه المالك الحقيقي (المستخدم الجذر ). 

[s‏ عرض قائمة بالملفات والدلائل» و [- لاعطاء التفاصیل, للأمر 
wall‏ (لاحظ وجود حرف x‏ في الاذونات وهو إذن Setgid‏ » 
لذلك فانه Sia‏ من قبل أعضاء المجموعة المُشغلین للامر وکأنهم 


مجموعة المالکین الحقيقين (tty)‏ 


Command -option string 


ls -ld /tmp 


ls -ld /var/tmp 


ls -l /etc/shadow 


ls -l /usr/bin/passwd 


ls -l /usr/bin/wall 


A‏ اساسیات لینکس 


echo‏ يقوم بالإخراج على الشاشة للكلمة "data"‏ وعلامة 
التوجيه < تعني إعادة توجيه الأمر إلى الملف source‏ 

وا عرض قائمة بالملفات والدلائل» و -l‏ لإعطاء التفاصيل» و أ 
لعرض رقم Source cil. inode‏ . 

.hardlink و‎ source لإنشاء ارتباط صلبء بين الملف‎ In 
لاحظ: الارتباط الصلب فقط بين الملفات.‎ 

وا عرض قائمة بالملفات والدلائل» و -l‏ لإعطاء التفاصيل» و أ 


لعرض رقم inode‏ ۰ للملفين source‏ و hardlink‏ . 


. 5310100 لإنشاء ارتباط صلب« بین الملف ۵۲۵۱0۲ و‎ In 


لعرض رقم node‏ للملفات .source«hardtoo«hardlink‏ 


. 1310100 آمر حذف. للارتباط‎ rm 

0 لانشاء ارتباط صلب. و- لجعله ارتباط رمزي بین الملف 
۵ والملف .Softlink‏ 

0 لانشاء ارتباط صلب. -s‏ لجعله ارتباط رمزي بين الدلیل 
6 و الملف .crossdir‏ 


لاحظ: الارتباط الرمزي يكون مع الملفات وأيضاً الدلائل. 


echo "data" > 6 


ls -li source 


ln source ٣۸ 


ls -li source ٣۸ 


ln hardlink hardtoo 


ls -li hardlink hardtoo 


source 


rm hardtoo 


ln -s source softlink 


ln -s /proc crossdir 


ls -l crossdir 


IL 


n.d. Web. 25 Mar. 2016. "NDG Linux Essentials." Cisco Networking Academy. N.p. 


«https://1299123.netacad.com/courses/362135». 
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